`

event.cancelBubble的理解

    博客分类:
  • WEB
阅读更多

于event.cancelBubble2007-09-07 11:45由于HTML中的对象都是层次结构,比如一个Table包含了多个TR,一个TR包含了多个TD Bubble就是一个事件可以从子节点向父节点传递,比如鼠标点击了一个TD,当前的event.srcElement就是这个TD,但是这种冒泡机制使你可以从TR或者Table处截获这个点击事件,但是如果你event.cancelBubble,则就不能上传事件。 例子:

<html> 
<body> 
<table border="1" width="26%" id="tableA" onclick="alert('tableA')"> 
<tr onclick="tableA_rowA_click()"> 
   <td width="106">一般</td> 
</tr> 
<tr onclick="tableA_rowB_click()"> 
   <td width="106">阻止消息上传</td> 
</tr> 
</table> 
</body> 
</html> 
<!--   --> 
<mce:script language="javascript"><!--
 
function tableA_rowA_click(){ 
alert('tableA_rowA'); 
} 
function tableA_rowB_click(){ 
alert('tableA_rowB'); 
event.cancelBubble=true; 
}
// --></mce:script> 
 

取消事件冒泡: 在 IE 的事件机制中,触发事件会从子元素向父元素逐级上传,就是说,如果子元素触发了单击事件,那么也会触发父元素的单击事件;event.cancelBubble=true;可以停止事件继续上传. 补充一点,Ie的事件传递是从下到上的: 事件来源对象->上级对象->上上级对象->.....->body->document->window . 例子:

 

<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title>event.cancelBubble</title> 
<mce:style><!--
 
* {font:menu}
--></mce:style><style mce_bogus="1"> 
* {font:menu}</style> 
</head> 
<body> 
<span onclick=alert("你好")>点我 <span>再点我</span></span><br><br> 
<span onclick=alert("你好")>点我 <span onclick=event.cancelBubble=true;>再点我</span></span> 
</body> 
</html> 

 

下面再看一个例子:

<html xmlns="http://www.w3.org/1999/xhtml" lang="zh" xml:lang="zh"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> 
<meta name="developer" content="Realazy" /> 
<title>Bubble in JavaScript DOM--JavaScript 的事件冒泡 demo </title> 
<mce:style type="text/css" media="screen"><!--
 
div * {display:block; margin:4px; padding:4px; border:1px solid white;} 
textarea {width:20em; height:2em;} 
--></mce:style><style type="text/css" media="screen" mce_bogus="1"> 
div * {display:block; margin:4px; padding:4px; border:1px solid white;} 
textarea {width:20em; height:2em;} </style> 
<mce:script type="text/javascript"><!--
 
      function init(){ 
    var log = document.getElementsByTagName('textarea')[0]; 
    var all = document.getElementsByTagName('div')[0].getElementsByTagName('*'); 
    for (var i = 0, n = all.length; i < n; ++i){ 
     all[i].onmouseover = function(e){ 
      this.style.border = '1px solid red'; 
      log.value = '鼠标现在进入的是: ' + this.nodeName; 
     }; 
     all[i].onmouseout = function(e){ 
      this.style.border = '1px solid white'; 
     }; 
    } 
    var all2 = document.getElementsByTagName('div')[1].getElementsByTagName('*'); 
    for (var i = 0, n = all2.length; i < n; ++i){ 
       all2[i].onmouseover = function(e){ 
      this.style.border = '1px solid red'; 
      if (e) //停止事件冒泡 
       e.stopPropagation(); 
      else 
       window.event.cancelBubble = true; 
      log.value = '鼠标现在进入的是: ' + this.nodeName; 
     }; 
   
   
     all2[i].onmouseout = function(e){ 
      this.style.border = '1px solid white';}; 
     } 
   
    } 
window.onload = init;
// --></mce:script> 
</head> 
<body> 
<h1>Bubble in JavaScript DOM</h1> 
<p>DOM树的结构是:</p> 
<pre><code> 
UL 
    - LI 
       - A 
     - SPAN 
</code></pre> 
<div> 
<ul> 
    <li><a href="#" mce_href="#"><span>Bubbllllllllllllllle</span></a></li> 
    <li><a href="#" mce_href="#"><span>Bubbllllllllllllllle</span></a></li> 
</ul> 
</div> 
<textarea></textarea></p>
<p>鼠标进入UL的任何一个子元素,如果不停止冒泡,我们从UL到SPAN都定义了鼠标悬停(<code>mouseover</code>)事件,这个事件会上升了UL,从而从鼠标所进入的元素到UL元素都会有红色的边。</p>
<div> 
<ul>
<li><a href="#" mce_href="#">Bubbllllllllllllllle</a></li>
<li><a href="#" mce_href="#">Bubbllllllllllllllle</a></li>
</ul>
</div>
<p>如果停止冒泡,事件不会上升,我们就可以获取精确的鼠标进入元素。</p></body> 
</html>

 
分享到:
评论

相关推荐

    IE的事件传递-event.cancelBubble示例介绍

    关于event.cancelBubble,由于HTML中的对象都是层次结构,比如一个Table包含了多个TR,一个TR包含了多个TD Bubble就是一个事件可以从子节点向父节点传递,比如鼠标点击了一个TD,当前的event.srcElement就是这个TD,...

    关于event.cancelBubble和event.stopPropagation()的区别介绍

    cancelBubble用于ie的阻止冒泡事件,event.stopPropagation()用于firefox和chrome等其他浏览器。 先不讲上面是对是错 先看一个例子:(测试环境:chrom5.0.275.7, moz3.6.4, opera10.53, ie6,7,8) 代码如下: &lt...

    eWebEditor不支持IE8/IE7的解决方法

    event.cancelBubble = true; return false; } var image = event.srcElement; var element = image.parentElement; //if (element.YUSERONCLICK) (element.YUSERONCLICK + "anonymous()");这句是自带语句!注释...

    Javascript 阻止javascript事件冒泡,获取控件ID值

    else//IE window.event.cancelBubble = true; 2.获取控件ID 代码如下:if (document.all) { //IE alert&#40;event.srcElement.tagName+”:”+event.srcElement.id&#41;; } else { //Firefox alert&#40;event.target....

    javascript右击屏蔽事件 js右击屏蔽

    一段javascript事件可以屏蔽网站右击的事件。...if (window.Event) document.captureEvents(Event.MOUSEUP); function nocontextmenu() { event.cancelBubble = true event.returnValue = false; . . . . . . .

    C#编写的web自定义日期选择控件带演示

     将InputCalendar.cs中output.WriteLine("parent.event.cancelBubble=true;");一句去掉即可。这一句的意义是:设置或获取当前事件是否要在事件句柄中向上冒泡。当前应用中好像没有用,所以去掉也不要紧。

    Event对象详解

    if (window.event.srcElement.tagName == "A" && window.event.shiftKey) window.event.returnValue = false; } ()"&gt; 下面的例子在状态栏上显示鼠标的当前位置。 &lt;BODY onmousemove="window.status = 'X=' + ...

    禁止F5等快捷键的JS代码

    禁止shift+f10 禁止鼠标右键or左右键 和禁止f5 的JS代码 [removed] //禁止ctrl+n和 禁止ctrl+r和 禁止shift+f10 禁止鼠标右键or左右键 和禁止f5 var oLastBtn=0,bIsMenu=false if (window.Event) ...

    javascript demo 基本技巧

    2.IE浏览器默认的功能停止 (Tab键在地址栏等中的移动停止) 代码如下:function stopDefaultKey(){ window.event.cancelBubble = true; //—取消该事件的冒泡。 window.event.returnValue = false; //事件返回false...

    js停止冒泡和阻止浏览器默认行为的简单方法

    停止冒泡通用方法: function stopBubble(e) { ... window.event.cancelBubble = true; } 阻止浏览器默认行为-通用方法 //阻止浏览器的默认行为 function stopDefault( e ) { //阻止默认浏览器动作(W3C) if

    JS 事件绑定函数代码

    代码如下: var bind=function(object,type,fn){ if(object.attachEvent){//IE浏览器 object.attachEvent(“on”+type,(function(){ return function(event){ window.event.cancelBubble=true;//停止时间冒泡 object...

    javascript阻止事件冒泡和浏览器的默认行为

    1.阻止事件冒泡,使成为捕获型事件触发机制. ... window.event.cancelBubble = true; } 2.当按键后,不希望按键继续传递给如HTML文本框对象时,可以取消返回值.即停止默认事件默认行为. //阻止浏览器的默认行为 functi

    浅谈js停止事件冒泡 阻止浏览器的默认行为(阻止超连接 #)

    在前端开发工作中,由于浏览器兼容性等问题,我们会经常用到“停止事件冒泡”和“阻止...window.event.cancelBubble = true; return false; 2.阻止浏览器的默认行为 JavaScript代码 //如果提供了事件对象,则这是

    JS阻止冒泡事件以及默认事件发生的简单方法

    代码如下:function stopBubble(e){ if(e&&e.... } else{//IE window.event.cancelBubble=true; } } 如果要阻止默认事件的触发,即默认的href事件,那么就需要调用如下函数: 代码如下:function stopD

    Div 制作的SELECT

    window.event.cancelBubble = true;"); } else if(!isIE){ selects[i].onclick = new Function("clickLabels3('"+selects[i].name+"')"); selects[i].addEventListener("click", stopBubbling, false); ...

    JavaScript阻止事件冒泡示例分享

    之前遇到事件冒泡的问题,也去网上搜索了一番,结果大部分都是一样的代码,贴来用时也不太顺利。涉及到FF时,可以用 e.stopPropagation();... e : window.event;//兼容FF  evt.cancelBubble = true; //evt.stopPro

    js禁止页面刷新禁止用F5键刷新禁止右键的示例代码

    代码如下: [removed] /... event.cancelBubble = true; return false; } } //禁止右键弹出菜单 function [removed]() { return false; } //下面代码实现全屏显示 function [removed](){ var Request = new Array();//保

Global site tag (gtag.js) - Google Analytics