jQuery點(diǎn)擊其他地方時(shí)菜單消失的實(shí)現(xiàn)方法
本文實(shí)例講述了jQuery點(diǎn)擊其他地方時(shí)菜單消失的實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
<script type="text/javascript">
function stopPropagation(e) {
if (e.stopPropagation)
e.stopPropagation();//停止冒泡 非ie
else
e.cancelBubble = true;//停止冒泡 ie
}
$(document).bind('click',function(){
$('#test').css('display','none');
});
$('#test').bind('click',function(e){
//寫(xiě)要執(zhí)行的內(nèi)容....吥啦不啦
stopPropagation(e);//調(diào)用停止冒泡方法,阻止document方法的執(zhí)行
});
</script>
事情是這樣的,比如我點(diǎn)擊一個(gè)div顯示出一個(gè)菜單,當(dāng)點(diǎn)擊其他地方,菜單消失,其中一個(gè)思路就是給document綁定上click事件,如果是點(diǎn)擊div就顯示菜單,如果是點(diǎn)擊document就隱藏菜單,但是如果點(diǎn)擊div也等于是點(diǎn)擊了document,所以在點(diǎn)擊div的事件里面執(zhí)行完要執(zhí)行的語(yǔ)句,然后終止js的冒泡,否則會(huì)既執(zhí)行了div的點(diǎn)擊事件,又繼續(xù)冒泡到document事件上,執(zhí)行了document的click的內(nèi)容
我的意思就是div也屬于document,所以點(diǎn)擊div也是點(diǎn)擊了document,所以在不進(jìn)行任何限制的情況下,點(diǎn)擊div的時(shí)候,div和document的方法都會(huì)執(zhí)行,進(jìn)行限制的具體內(nèi)容就是在點(diǎn)擊div的方法里面停止冒泡,具體方法就是用e.stopPropagation()→"適用于非ie"方法,如果是ie就是e.cancelBubble=true
還有一種思路就是在document的click方法中判斷觸發(fā)的源是哪一個(gè),如果是div的話就不執(zhí)行任何操作也就是return,如果不是div的話,那就將菜單隱藏具體如下
event對(duì)象包含了一個(gè)重要屬性:target(W3C)/srcElement(IE),這個(gè)屬性標(biāo)識(shí)了觸發(fā)事件的原始元素,思路二就是要利用這個(gè)屬性。我們可以直接對(duì)document的click事件綁定事件處理程序,在事件處理程序中判讀事件源是否為id==test的div元素或其子元素,如果是則方法return不做操作,如果不是則隱藏該div。
$(document).bind('click',function(e){
var e = e || window.event; //瀏覽器兼容性
var elem = e.target || e.srcElement;
while (elem) { //循環(huán)判斷至跟節(jié)點(diǎn),防止點(diǎn)擊的是div子元素
if (elem.id && elem.id=='test') {
return;
}
elem = elem.parentNode;
}
$('#test').css('display','none'); //點(diǎn)擊的不是div或其子元素
});
更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jQuery操作json數(shù)據(jù)技巧匯總》、《jQuery切換特效與技巧總結(jié)》、《jQuery拖拽特效與技巧總結(jié)》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery常見(jiàn)經(jīng)典特效匯總》、《jQuery動(dòng)畫(huà)與特效用法總結(jié)》、《jquery選擇器用法總結(jié)》及《jQuery常用插件及用法總結(jié)》
希望本文所述對(duì)大家jQuery程序設(shè)計(jì)有所幫助。
- jquery實(shí)現(xiàn)隱藏在左側(cè)的彈性彈出菜單效果
- jQuery實(shí)現(xiàn)的精美平滑二級(jí)下拉菜單效果代碼
- 基于jquery實(shí)現(xiàn)無(wú)限級(jí)樹(shù)形菜單
- 基于jquery實(shí)現(xiàn)百度新聞導(dǎo)航菜單滑動(dòng)動(dòng)畫(huà)
- jquery實(shí)現(xiàn)右側(cè)欄菜單選擇操作
- jQuery zTree加載樹(shù)形菜單功能
- jquery實(shí)現(xiàn)具有收縮功能的垂直導(dǎo)航菜單
- Jquery實(shí)現(xiàn)縱向橫向菜單
- 基于jQuery實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊導(dǎo)航菜單水波動(dòng)畫(huà)效果附源碼下載
- jQuery實(shí)現(xiàn)二級(jí)下拉菜單效果
- jquery實(shí)現(xiàn)樹(shù)形菜單完整代碼
- jquery實(shí)現(xiàn)二級(jí)導(dǎo)航下拉菜單效果
相關(guān)文章
Jquery 實(shí)現(xiàn)Tab效果 思路是js思路
Jquery 實(shí)現(xiàn)Tab效果,思路就是普通的用js的思路控制的,腳本之家發(fā)布過(guò)更精簡(jiǎn)的代碼,這個(gè)比較適合一直用js開(kāi)始學(xué)用jquery控制的朋友一個(gè)參考。2010-03-03
jQuery實(shí)現(xiàn)DIV響應(yīng)鼠標(biāo)滑過(guò)由下向上展開(kāi)效果示例【測(cè)試可用】
這篇文章主要介紹了jQuery實(shí)現(xiàn)DIV響應(yīng)鼠標(biāo)滑過(guò)由下向上展開(kāi)效果,涉及jQuery基于事件響應(yīng)結(jié)合stop與animate方法控制頁(yè)面元素屬性動(dòng)態(tài)變換相關(guān)操作技巧,需要的朋友可以參考下2018-04-04
jquery插件實(shí)現(xiàn)鼠標(biāo)隱藏
這篇文章主要為大家詳細(xì)介紹了jquery插件實(shí)現(xiàn)鼠標(biāo)隱藏,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05
jQuery獲取多種input值的簡(jiǎn)單實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇jQuery獲取多種input值的簡(jiǎn)單實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-06-06
jquery easyUI中ajax異步校驗(yàn)用戶名
這篇文章主要為大家詳細(xì)介紹了jquery easyUI中ajax異步校驗(yàn)用戶名,感興趣的小伙伴們可以參考一下2016-08-08
Bootstrap框架建立樹(shù)形菜單(Tree)的實(shí)例代碼
這篇文章主要介紹了在Bootstrap框架下怎么去建立一個(gè)樹(shù)形菜單,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2017-10-10
jquery實(shí)現(xiàn)根據(jù)瀏覽器窗口大小自動(dòng)縮放圖片的方法
這篇文章主要介紹了jquery實(shí)現(xiàn)根據(jù)瀏覽器窗口大小自動(dòng)縮放圖片的方法,涉及jquery操作頁(yè)面元素屬性與樣式的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07
關(guān)于錨點(diǎn)跳轉(zhuǎn)及jQuery下相關(guān)操作與插件
錨點(diǎn)嘛,業(yè)余點(diǎn)的解釋就是可以讓頁(yè)面定位到某個(gè)位置的點(diǎn)。在高度較高的頁(yè)面中經(jīng)常見(jiàn)到2012-10-10
jquery中交替點(diǎn)擊事件的實(shí)現(xiàn)代碼
這篇文章主要介紹了jquery中交替點(diǎn)擊事件的實(shí)現(xiàn)代碼,需要的朋友可以參考下2014-02-02

