溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

jQuery怎么實(shí)現(xiàn)點(diǎn)擊其他地方時(shí)菜單消失

發(fā)布時(shí)間:2022-10-23 12:57:26 來(lái)源:億速云 閱讀:109 作者:iii 欄目:web開(kāi)發(fā)

這篇文章主要介紹“jQuery怎么實(shí)現(xiàn)點(diǎn)擊其他地方時(shí)菜單消失”,在日常操作中,相信很多人在jQuery怎么實(shí)現(xiàn)點(diǎn)擊其他地方時(shí)菜單消失問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”jQuery怎么實(shí)現(xiàn)點(diǎn)擊其他地方時(shí)菜單消失”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

具體代碼如下:

<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í)行的內(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怎么實(shí)現(xiàn)點(diǎn)擊其他地方時(shí)菜單消失”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI