JavaScript 的事件冒泡 demo

來源:互聯網
上載者:User
 

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  2.  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml" lang="zh" xml:lang="zh">
  4. <head>
  5. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
  6. <meta name="developer" content="Realazy" />
  7. <title>Bubble in JavaScript DOM</title>
  8. <style type="text/css" media="screen">
  9.  div * {display:block; margin:4px; padding:4px; border:1px solid white;}
  10.  textarea {width:20em; height:2em;}
  11. </style>
  12. <script type="text/javascript">
  13.     //<![CDATA[
  14.     function init(){
  15.   var log = document.getElementsByTagName('textarea')[0];
  16.   var all = document.getElementsByTagName('div')[0].getElementsByTagName('*');
  17.   for (var i = 0, n = all.length; i < n; ++i){
  18.    all[i].onmouseover = function(e){
  19.     this.style.border = '1px solid red';
  20.     log.value = '滑鼠現在進入的是: ' + this.nodeName;
  21.    };
  22.    all[i].onmouseout = function(e){
  23.     this.style.border = '1px solid white';
  24.    };
  25.   }
  26.   var all2 = document.getElementsByTagName('div')[1].getElementsByTagName('*');
  27.   for (var i = 0, n = all2.length; i < n; ++i){
  28.    all2[i].onmouseover = function(e){
  29.     this.style.border = '1px solid red';
  30.     if (e) //停止事件冒泡
  31.      e.stopPropagation();
  32.     else
  33.      window.event.cancelBubble = true;
  34.     
  35.     log.value = '滑鼠現在進入的是: ' + this.nodeName;
  36.    };
  37.    all2[i].onmouseout = function(e){
  38.     this.style.border = '1px solid white';
  39.    };
  40.   }
  41.  }
  42.  window.onload = init;
  43.     //]]>
  44. </script>
  45. </head>
  46. <body>
  47. <h1>Bubble in JavaScript DOM</h1>
  48. <p>DOM樹的結構是:</p>
  49. <pre><code>
  50. UL
  51.   - LI
  52.      - A
  53.    - SPAN
  54. </code></pre>
  55. <div>
  56.  <ul>
  57.   <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
  58.   <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
  59.  </ul>
  60. </div>
  61. <textarea></textarea>
  62. <p>滑鼠進入UL的任何一個子項目,如果不停止冒泡,我們從UL到SPAN都定義了滑鼠移至上方(<code>mouseover</code>)事件,這個事件會上升了UL,從而從滑鼠所進入的元素到UL元素都會有紅色的邊。</p>
  63. <div>
  64.  <ul>
  65.   <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
  66.   <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
  67.  </ul>
  68. </div>
  69. <p>如果停止冒泡,事件不會上升,我們就可以擷取精確的滑鼠進入元素。</p>
  70. </body>
  71. </html>
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.