取消事件冒泡
2011-01-09 12:43
316 查看
IE 的事件机制中,触发事件会从子元素向父元素逐级上传,如果子元素触发了单击事件,那么也会触发父元素的单击事件;event.cancelBubble=true;可以停止事件继续上传。补充一点,ie的事件传递是从下到上的:
事件来源对象->上级对象->上上级对象->.....->body->document->window
NS的事件传递是从上到下:
window->document->body->....->事件来源对象实例源码如下:
事件来源对象->上级对象->上上级对象->.....->body->document->window
NS的事件传递是从上到下:
window->document->body->....->事件来源对象实例源码如下:
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>event.cancelBubble</title> <style> <!-- * {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>
实例2:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <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> <style type="text/css" media="screen"> div * {display:block; margin:4px; padding:4px; border:1px solid white;} textarea {width:20em; height:2em;} </style> <script type="text/javascript"> //<![CDATA[ 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; //]]> </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="#"><span>Bubbllllllllllllllle</span></a></li> <li><a href="#"><span>Bubbllllllllllllllle</span></a></li> </ul> </div> <textarea></textarea> <p>鼠标进入UL的任何一个子元素,如果不停止冒泡,我们从UL到SPAN都定义了鼠标悬停(<code>mouseover</code>)事件,这个事件会上升了UL,从而从鼠标所进入的元素到UL元素都会有红色的边。</p> <div> <ul> <li><a href="#"><span>Bubbllllllllllllllle</span></a></li> <li><a href="#"><span>Bubbllllllllllllllle</span></a></li> </ul> </div> <p>如果停止冒泡,事件不会上升,我们就可以获取精确的鼠标进入元素。</p> </body> </html>
相关文章推荐
- JS 取消冒泡事件 兼容火狐IE
- jQuery中处理事件冒泡的方法和取消后续内容的方法
- JavaScript之事件的处理模型---事件冒泡,捕获及取消冒泡,阻止默认事件
- 必须取消事件冒泡情况
- 关于什么是事件冒泡和如何取消事件冒泡的讨论!
- 取消事件冒泡(多个事件重复发生)
- js 取消冒泡事件
- js取消事件冒泡和阻止事件的默认行为(兼容写法)
- 取消事件冒泡(大小DIV)
- js取消事件冒泡方法
- 取消事件冒泡机制和阻止事件默认行为
- 动态生成三级菜单+前端事件处理(冒泡机制取消)
- jquery取消事件冒泡的三种方法(推荐)
- js取消事件冒泡
- event事件对象 兼容写法:var oEvent=ev||event;和取消事件冒泡
- jQuery取消事件冒泡
- 如何给元素添加事件监听和取消事件冒泡
- 浏览器兼容:取消冒泡事件
- 取消事件冒泡
- JQuery中 取消后续事件的执行,取消事件冒泡