`

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>

 
分享到:
评论

相关推荐

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

    在JavaScript的事件处理中,`event.cancelBubble` 和 `event.stopPropagation()` 都是用来控制事件冒泡的行为,但它们之间存在一些关键的区别。事件冒泡是指事件从最深的节点开始,逐级向上层节点传播事件的过程。...

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

    以下是一个简单的例子,帮助你理解`event.cancelBubble`的使用: ```html ('tableA')"&gt; ()"&gt; 一般 ()"&gt; 阻止消息上传 &lt;p&gt;  function tableA_rowA_click() { alert('tableA_rowA'); } function...

    如何禁用一些快捷键?怎么禁用快捷键?

    event.cancelBubble = true; event.returnValue = false; return false; } function norightclick(e) { if (window.Event) { if (e.which != 1) { // 如果不是左键点击 return false; } } else { if ...

    js阻止默认浏览器行为与冒泡行为的实现代码.docx

    总的来说,理解和正确使用`event.preventDefault()`和`event.stopPropagation()`是JavaScript事件处理中的关键技能,它们能够帮助开发者实现更灵活的交互和控制。在实际项目中,根据具体需求选择合适的方法,确保...

    高手window.event对象详解

    - **定义**:`event.cancelBubble` 属性用于控制事件是否冒泡到父元素。 - **值**: - `true` 表示取消事件冒泡; - `false` 表示允许事件冒泡,默认值。 - **应用场景**:在处理嵌套元素的事件时,可以通过...

    js阻止冒泡及jquery阻止事件冒泡示例介绍.docx

    W3C标准的`event.stopPropagation()`被现代浏览器广泛支持,而IE浏览器则使用`event.cancelBubble = true;`。 ```javascript function stopPropagation(e) { var evt = e || window.event; if (evt....

    JS经常用到的一些技术

    event.cancelBubble = true; event.returnValue = false; return false; } } ()" oncontextmenu="nocontextmenu()"&gt; ``` 这段代码通过监听`onmousedown`和`oncontextmenu`事件来阻止用户在页面上使用鼠标...

    封装自己的js工具-Event.txt

    ### 封装自己的JavaScript工具——Event 在前端开发过程中,事件处理是不可或缺的一部分。不同的浏览器对事件的支持...对于初学者来说,这也是一个很好的学习实践机会,有助于理解不同浏览器之间事件处理机制的差异。

    JavaScript阻止事件冒泡示例分享

    总的来说,理解和熟练运用`event.stopPropagation()`、`event.cancelBubble`以及`event.preventDefault()`是编写健壮的JavaScript事件处理程序的关键。在编写代码时,应考虑各种浏览器的兼容性问题,以确保代码能在...

    javascript 拖动

    else event.cancelBubble = true; // IE if (event.preventDefault) event.preventDefault(); // DOM Level 2 else event.returnValue = false; // IE function moveHandler(e) { if (!e) e = window.event; /...

    09JavaScript事件总结.docx

    这在很多情况下是有益的,但有时也需要阻止冒泡,如使用`event.cancelBubble = true`来实现。 五、事件委托(Delegation) 事件委托是一种优化技术,通过在共同的父元素上绑定事件监听器,而不是在每个子元素上单独...

    浅谈javascript事件取消和阻止冒泡

    W3C提供`event.stopPropagation()`方法来实现这一点,而IE则使用`event.cancelBubble = true`。例如: ```javascript function stopHandler(event) { window.event ? window.event.cancelBubble = true : event....

    jsp 页面禁用刷新

    在探讨“JSP页面禁用刷新”的主题时,我们首先需要理解JSP(Java Server Pages)的基本概念及其在Web开发中的角色。JSP是一种用于创建动态网页的技术,它允许将HTML、XML、脚本语言(如JavaScript)以及Java代码混合...

    禁止右键代码示例demo

    通过判断`event.which`或`event.button`的值来确定是否为右键点击,如果是,则通过设置`cancelBubble`和`returnValue`属性来阻止事件冒泡和默认行为的发生。 ##### 方法四:禁用文本选择 除了禁止右键点击外,有些...

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

    总的来说,理解并正确使用`stopPropagation()`、`preventDefault()`、`cancelBubble`和`returnValue`属性是JavaScript事件处理中的关键技巧。这些方法可以帮助开发者更精细地控制事件流,提高用户体验,同时避免因...

    解除网页 鼠标右键锁定 源码.text

    它总是返回`true`,允许事件继续传播,同时设置`event.returnValue`和`event.cancelBubble`来确保事件正常执行而不被阻断。 4. **DOMContentLoaded事件监听器**:这段代码在文档加载完成后调用`unlockMouse`函数,...

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

    理解和熟练使用`event.stopPropagation()`和`event.preventDefault()`是前端开发者必备的技能。它们可以帮助你精确控制事件的处理流程,避免不必要的副作用,同时提供更个性化的用户体验。在实际开发中,结合这两种...

    javascript自动切换焦点控制效果完整实例.docx

    event.cancelBubble = true; } } }; var dom_text1 = document.getElementById("text1"); var dom_text2 = document.getElementById("text2"); var dom_text3 = document.getElementById("text3"); ...

    js如何取消事件冒泡

    2. **`window.event.cancelBubble = true`**:这是针对IE浏览器的解决方案。在IE中,`event`对象不是默认传递给事件处理函数的,因此需要通过`window.event`来访问。设置`cancelBubble`属性为`true`可以阻止事件冒泡...

    【JavaScript源代码】Javascript实现单选框效果.docx

    而在IE浏览器中,则需要使用`event.cancelBubble = true`。为了兼容不同浏览器,可以这样写: ```javascript e.stopPropagation ? e.stopPropagation() : e.cancelBubble = true; ``` 下面是一个完整的示例,展示...

Global site tag (gtag.js) - Google Analytics