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)容感興趣的讀者可查看本站專(zhuān)題:《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模擬picker實(shí)現(xiàn)滑動(dòng)選擇效果
這篇文章主要為大家詳細(xì)介紹了jquery模擬picker實(shí)現(xiàn)滑動(dòng)選擇效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04jQuery實(shí)現(xiàn)獲取及設(shè)置CSS樣式操作詳解
這篇文章主要介紹了jQuery實(shí)現(xiàn)獲取及設(shè)置CSS樣式操作,結(jié)合實(shí)例形式分析了jQuery中常用的addClass()、removeClass()、toggleClass()及css()相關(guān)使用方法及操作注意事項(xiàng),需要的朋友可以參考下2018-09-09jQuery+ThinkPHP實(shí)現(xiàn)圖片上傳
這篇文章主要為大家詳細(xì)介紹了jQuery+ThinkPHP實(shí)現(xiàn)圖片上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07JQuery制作的放大效果的popup對(duì)話框(未添加任何jquery plugin)分享
分享一個(gè)JQuery制作的放大效果的popup對(duì)話框(未添加任何jquery plugin)項(xiàng)目中可以根據(jù)自己的需求來(lái)寫(xiě)css,感興趣的朋友可以了解下哈2013-04-04jQuery實(shí)現(xiàn)灰藍(lán)風(fēng)格標(biāo)準(zhǔn)二級(jí)下拉菜單效果代碼
這篇文章主要介紹了jQuery實(shí)現(xiàn)灰藍(lán)風(fēng)格標(biāo)準(zhǔn)二級(jí)下拉菜單效果代碼,涉及jquery鼠標(biāo)mouseover事件控制頁(yè)面元素樣式動(dòng)態(tài)變換的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08jQuery3.0中的buildFragment私有函數(shù)詳解
在 jQuery3.0中,buildFragment 是一個(gè)私有函數(shù),用來(lái)構(gòu)建一個(gè)包含子節(jié)點(diǎn) fragment 對(duì)象。下文給大家介紹jQuery3.0中的buildFragment私有函數(shù)詳解,對(duì)jquery3.0 buildfragment相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-08-08jQuery下實(shí)現(xiàn)等待指定元素加載完畢(可改成純js版)
下面就是我想到的等待元素出現(xiàn)方法,雖然是基于jQuery的,但是代碼很簡(jiǎn)潔,可以修改成純js版的,感興趣的朋友可以參考下哈,希望對(duì)大家有所幫助2013-07-07