我是FE,也是Fe

          前端來源于不斷的點(diǎn)滴積累。我一直在努力。

          統(tǒng)計(jì)

          留言簿(15)

          閱讀排行榜

          評論排行榜

          jQuery中的stopImmediatePropagation與stopPropagation的區(qū)別

          有這么個需求。要在一個文本框上監(jiān)聽兩個事件,例如:
           
          <script type="text/javascript">
                  $(
          function(){
                      $(
          "#t").keyup(function(e){
                          $(
          "#s").html("keyup1");
                          
          //stopImmediatePropagation可以阻止在這之后綁定的事件
                          //比較注釋和不注釋這一行的區(qū)別
                          e.stopImmediatePropagation();
                      });
                      $(
          "#t").keyup(function(e){
                          $(
          "#s").html("keyup2");
                      });
                  });
              
          </script>
          <input type="text" id="t" name="" value="" />
          <span class="" id="s"></span>
           
          如果在第一個事件中需要阻止第二個事件的執(zhí)行可以在第一個事件中使用event.stopImmediatePropagation方法。jQuery的event的對象是增強(qiáng)的event對象,
          stopImmediatePropagation就是jQuery獨(dú)有的一種阻止jQuery綁定事件機(jī)制。可以通過isImmediatePropagationStopped()來判斷是否阻止了jQuery立即冒泡。
           
          stopImmediatePropagation的實(shí)現(xiàn)可以參見我之前的一篇文章,從jQuery的緩存到事件監(jiān)聽 在這篇文章中提到j(luò)Query將事件都緩存在一個數(shù)組中按照先后順序執(zhí)行。如果stopImmediatePropagation就停止執(zhí)行數(shù)組中的監(jiān)聽函數(shù)。
           
          stopPropagation是阻止默認(rèn)事件監(jiān)聽函數(shù)。不是jQuery獨(dú)有,阻止默認(rèn)事件的冒泡,比如監(jiān)聽了DOM節(jié)點(diǎn)和該節(jié)點(diǎn)的父節(jié)點(diǎn)的事件,默認(rèn)是事件執(zhí)行將從里到外,這就是所謂的冒泡。在IE9-瀏覽器中可以使用event.cancelBubble=false來做到,標(biāo)準(zhǔn)瀏覽器使用event.stopPropagation方法。jQuery也把stopPropagation擴(kuò)展方式到IE上這樣有了一致的方法。
           
          綜上所述,其實(shí)stopImmediatePropagation與stopPropagation就不是一個東西,所以也不存在什么區(qū)別了。
          參考資料
          http://api.jquery.com/event.stopImmediatePropagation/
          http://stackoverflow.com/questions/5299740/jquery-stoppropagation-vs-stopimmediatepropagation
          http://api.jquery.com/event.stopImmediatePropagation/
          http://stackoverflow.com/questions/5299740/jquery-stoppropagation-vs-stopimmediatepropagation
           

          posted on 2011-05-06 18:04 衡鋒 閱讀(3249) 評論(2)  編輯  收藏 所屬分類: javascriptJqueryWeb開發(fā)

          評論

          # re: jQuery中的stopImmediatePropagation與stopPropagation的區(qū)別 2011-09-15 08:35 tb

          謝謝峰哥!!  回復(fù)  更多評論   

          # re: jQuery中的stopImmediatePropagation與stopPropagation的區(qū)別 2011-09-15 19:20 衡鋒

          @tb
          你認(rèn)識我?  回復(fù)  更多評論   

          主站蜘蛛池模板: 光山县| 新化县| 行唐县| 化州市| 普定县| 宿迁市| 侯马市| 临沭县| 交口县| 东海县| 遂川县| 濉溪县| 延津县| 汶上县| 会理县| 博白县| 尼木县| 古丈县| 丁青县| 资源县| 德阳市| 萍乡市| 宁城县| 旅游| 富顺县| 仁化县| 汉川市| 濮阳市| 博客| 罗山县| 肥乡县| 瑞昌市| 积石山| 烟台市| 合江县| 天全县| 温宿县| 阿鲁科尔沁旗| 永宁县| 饶阳县| 平原县|