JS事件冒泡(阻止)
来源:互联网 发布:淘宝店铺不支持7天退货 编辑:程序博客网 时间:2024/06/06 16:53
来源:http://blog.csdn.net/tnjun123456/article/details/7105935
在默认情况下,发生在一个子元素上的单击事件(或者其他事件),如果在其父级元素绑定了一个同样的事件,此时点击子元素,click事件会首先被子元素捕获,执行绑定的事件程序,之后会被父级元素捕获,再次激发一段脚本的执行,这就是所谓的“事件冒泡”。
看个例子:
- <!DOCTYPE html>
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title>无标题文档</title>
- <style type="text/css">
- *{ margin:0; padding:0;}
- </style>
- </head>
- <body>
- <div id="obj1" style=" width:500px; height:500px; background:#000;">
- <div id="obj2" style="width:400px; height:400px; background:red;"></div>
- </div>
- <script type="text/javascript">
- var obj1 = document.getElementById('obj1');
- var obj2 = document.getElementById('obj2');
- obj1.onclick = function(){
- alert('我点击了obj1');
- }
- obj2.onclick = function(e){
- alert('我点击了obj2');
- }
- </script>
- </body>
- </html>
在通常情况下,我们只希望事件发生在它的目标而并非它的父级元素上,只需加个stopBubble方法,即可取消事件冒泡,详见以下代码:
- <!DOCTYPE html>
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title>无标题文档</title>
- <style type="text/css">
- *{ margin:0; padding:0;}
- </style>
- </head>
- <body>
- <div id="obj1" style=" width:500px; height:500px; background:#000;">
- <div id="obj2" style="width:400px; height:400px; background:red;"></div>
- </div>
- <script type="text/javascript">
- //阻止事件冒泡的通用函数
- function stopBubble(e){
- // 如果传入了事件对象,那么就是非ie浏览器
- if(e&&e.stopPropagation){
- //因此它支持W3C的stopPropagation()方法
- e.stopPropagation();
- }else{
- //否则我们使用ie的方法来取消事件冒泡
- window.event.cancelBubble = true;
- }
- }
- var obj1 = document.getElementById('obj1');
- var obj2 = document.getElementById('obj2');
- obj1.onclick = function(){
- alert('我点击了obj1');
- }
- obj2.onclick = function(e){
- alert('我点击了obj2');
- stopBubble(e);
- }
- </script>
- </body>
- </html>
现在你可能想知道,什么时候需要阻止事件冒泡?事实上,现在绝大多数情况下都可以不必在意它。但是当你开始开发动态应用程序(尤其是需要处理键盘和鼠标)的时候,就有这个必要了。
0 0
- JS事件冒泡(阻止)
- JS事件冒泡(阻止)
- Js 冒泡事件阻止
- 阻止js事件冒泡
- JS阻止事件冒泡
- JS阻止事件冒泡
- Js 冒泡事件阻止
- JS事件冒泡(阻止
- js 阻止冒泡事件
- JS阻止冒泡事件
- JS阻止事件冒泡
- JS 阻止事件冒泡
- js阻止冒泡事件
- Js 冒泡事件阻止
- Js 冒泡事件阻止
- Js 冒泡事件阻止
- js阻止事件冒泡
- JS阻止事件冒泡
- HDU 1856 More is better 并查集
- Win10 兼容性 Visual studio web应用程序 ASP.NET 4.0 尚未在 Web 服务器上注册
- 常用试用在线帮助汇总
- DOM(二)-10-(示例-删除表格的行和列)
- 黑马程序员-----IO流(3)File类、打印流、序列化、管道流、字符编码等
- JS事件冒泡(阻止)
- opencv install for ubuntu
- Storm入门教程(一)
- 24. 引用类型
- 2015优秀文章收集
- 定时器与多线程 SetTimer and Multi-Thread 每个线程独立使用一个定时器
- module_init的调用顺序
- python的sorted函数对字典按key排序和按value排序
- Socket通信实例一