中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Javascript Event(事件)的傳播與冒泡

發布時間:2020-10-06 18:02:06 來源:腳本之家 閱讀:139 作者:小龍女先生 欄目:web開發

特性說明和原理圖:

Javascript Event(事件)的傳播與冒泡

  • 標準瀏覽器和Ie9+瀏覽器都支持事件的冒泡和捕獲,而IE8-瀏覽器只支持冒泡
  • 標準和Ie9+瀏覽器用stopPropagation()或cancelBubble阻止事件傳播,而ie8-用e.cancelBubble屬性來阻冒泡,注意ie9不支持cancelBubble屬性(設置后不生效),但chrome、safari、opera、firefox都支持cancelBubble屬性。
  • Ie8-用attachEvent為dom元素添加一個事件,但必須在事件名前加上on,此類事件只能在元素的冒泡階段。
  • stopPropagatin()方法用于阻止事件的傳播,如果設置在捕獲階段,則目標和冒泡階段不會被執行;
  • cancelBubble屬性只能阻止冒泡階段,對捕獲和目標階段的事件不能阻止
  • preventDefault()和window.event.returnValue用于標準瀏覽器和ie9+,都可以阻止默認事件。ie8-可以用returnValue,preventDefault()。

示例代碼(ie8-示例不提供)

html代碼

<body class="body" > 
 <div class="log"></div>
 <input type="text" id="inTxt" name="intxt" />
<div class="wrap">
 <div class="cont">
  <button type="button" class="button" id="btn">按鈕</button>
  <select name="stopType" id="stopType">
    <option value="1">StopPropagation</option>
    <option value="2">cancelBubble</option>
  </select>
  <button type="button" class="button" id="btnReject">cont阻止捕獲或冒泡</button>
 </div>
</div>
</body>

層級關系:body->wrap->cont->button,可以對照上面的原理

Js代碼

$(function(){
    var $log = $('.log'), 
      $wrap = $('.wrap'),
      $cont = $('.cont'),
      $btn = document.getElementById('btn'),
      $stopType = $('#stopType'),
      $body = $('body'),
      $inTxt = $('#inTxt'),
      $btnReject = $('#btnReject');
    var ePhase = ["","捕獲","目標","冒泡"]
    var setBorderColor = function( $dom, color, time,event){
      $dom = $($dom);
      $log.html($log.html() + $dom.attr('class') + '[' + ePhase[event.eventPhase] + ']' + '<br/>')
      var timeIndex = window.setTimeout(function(){   
      $dom.css({
        'borderColor': color,
        'borderWidth': '4px'
      });
      }, time);
    }  
    //捕獲
    $body[0].addEventListener('click',function(event){ 
      $log.html($log.html() + "-------------------<br>");
      setBorderColor($body,'#0866ff ',0,event);
    },true);  
    $wrap[0].addEventListener('click',function(event){
      setBorderColor($wrap,'yellow',2000,event); 
    },true);
    $cont[0].addEventListener('click',function(event){
      event = event || window.event;
      if( $stopType.val() == '1' ){
        event.stopPropagation();
      }else{
        event.cancelBubble = true;
      }
      setBorderColor($cont,'green',1000,event);  
    },true); 
    $btn.addEventListener('click', function(event){ 
      setBorderColor($btn,'red',0,event);
    },true);
    $btnReject[0].addEventListener('click',function(event){ 
      setBorderColor($btnReject,'gray ',0,event);
    },true);
    //冒泡
    $body[0].addEventListener('click',function(event){
      setBorderColor($body,'#0866ff ',0,event);
    },false); 
    $wrap[0].addEventListener('click',function(event){
      setBorderColor($wrap,'yellow',2000,event); 
    },false); 
    $cont[0].addEventListener('click',function(event){
      setBorderColor($cont,'green',1000,event);  
    },false); 
    $btn.addEventListener('click', function(event){ 
      setBorderColor($btn,'red',0,event);
    },false);
    $btnReject[0].addEventListener('click',function(event){ 
      setBorderColor($btnReject,'gray ',0,event);
    },false);
    //阻止默認事件
    $inTxt.keypress(function(event){
      //event.preventDefault(); 
      window.event.returnValue = false;
      $body.append( String.fromCharCode( event.keyCode ));
    });
  });
  1. 實現一個完整的event流的Demo
  2. 在cont的捕獲事件處有阻止事件傳播的代碼
  3. 阻止默認事件只用于驗證

效果圖

Javascript Event(事件)的傳播與冒泡

應用場景

  • 捕獲階段的事件應用場景較少,一般情況下都應用在目標和冒泡階段。
  • 現階段w3c的標準事件已普遍受支持,如果不兼容ie8-瀏覽器可以廢棄一些兼容性代碼。

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持億速云!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

靖远县| 驻马店市| 庆元县| 尼木县| 尼勒克县| 临夏市| 永德县| 和林格尔县| 辛集市| 通城县| 长治市| 梁平县| 武安市| 肥西县| 长宁县| 沙河市| 海伦市| 崇明县| 湘阴县| 阆中市| 江津市| 汉源县| 应城市| 松滋市| 巨野县| 湘潭县| 阳信县| 睢宁县| 车险| 阿克苏市| 景宁| 米易县| 洮南市| 诸暨市| 承德县| 黔西县| 高邮市| 敦煌市| 仙居县| 留坝县| 西盟|