這篇文章主要介紹了jQuery點擊其他地方時菜單消失的實現(xiàn)方法,結合實例形式分析了jQuery實現(xiàn)點擊其他地方讓菜單消失的實現(xiàn)思路與解決方法,需要的朋友可以參考下
本文實例講述了jQuery點擊其他地方時菜單消失的實現(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){
//寫要執(zhí)行的內容....吥啦不啦
stopPropagation(e);//調用停止冒泡方法,阻止document方法的執(zhí)行
});
</script>
事情是這樣的,比如我點擊一個div顯示出一個菜單,當點擊其他地方,菜單消失,其中一個思路就是給document綁定上click事件,如果是點擊div就顯示菜單,如果是點擊document就隱藏菜單,但是如果點擊div也等于是點擊了document,所以在點擊div的事件里面執(zhí)行完要執(zhí)行的語句,然后終止js的冒泡,否則會既執(zhí)行了div的點擊事件,又繼續(xù)冒泡到document事件上,執(zhí)行了document的click的內容
我的意思就是div也屬于document,所以點擊div也是點擊了document,所以在不進行任何限制的情況下,點擊div的時候,div和document的方法都會執(zhí)行,進行限制的具體內容就是在點擊div的方法里面停止冒泡,具體方法就是用e.stopPropagation()→"適用于非ie"方法,如果是ie就是e.cancelBubble=true
還有一種思路就是在document的click方法中判斷觸發(fā)的源是哪一個,如果是div的話就不執(zhí)行任何操作也就是return,如果不是div的話,那就將菜單隱藏具體如下
event對象包含了一個重要屬性:target(W3C)/srcElement(IE),這個屬性標識了觸發(fā)事件的原始元素,思路二就是要利用這個屬性。我們可以直接對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é)點,防止點擊的是div子元素
if (elem.id && elem.id=='test') {
return;
}
elem = elem.parentNode;
}
$('#test').css('display','none'); //點擊的不是div或其子元素
});
希望本文所述對大家jQuery程序設計有所幫助。