Bubble in JavaScript DOM

  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--JavaScript 的事件冒泡 demo </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.             log.value = '鼠标现在进入的是: ' + this.nodeName;
  35.         };
  36.         all2[i].onmouseout = function(e){
  37.         this.style.border = '1px solid white';};
  38.         }
  39.     }
  40. window.onload = init;
  41.       //]]>
  42. </script>
  43. </head>
  44. <body>
  45. <h1>Bubble in JavaScript DOM</h1>
  46. <p>DOM树的结构是:</p>
  47. <pre><code>
  48. UL
  49.     - LI
  50.        - A
  51.      - SPAN
  52. </code></pre>
  53. <div>
  54. <ul>
  55.     <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
  56.     <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
  57. </ul>
  58. </div>
  59. <textarea></textarea>
  60. <p>鼠标进入UL的任何一个子元素,如果不停止冒泡,我们从UL到SPAN都定义了鼠标悬停(<code>mouseover</code>)事件,这个事件会上升了UL,从而从鼠标所进入的元素到UL元素都会有红色的边。</p>
  61. <div>
  62. <ul>
  63.     <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
  64.     <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
  65. </ul>
  66. </div>
  67. <p>如果停止冒泡,事件不会上升,我们就可以获取精确的鼠标进入元素。</p>
  68. </body>
  69. </html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值