深入理解事件冒泡(Bubble)和事件捕捉(capture)
事件的发生顺序
假设在一个元素中又嵌套了另一个元素并且两者都有一个onClick事件处理函数(event handler)。如果用户单击元素2,则元素1和元素2的单击事件都会被触发。哪一个事件先被触发?哪一个事件处理函数会被执行?换句话说,事件的发生顺序到底如何?如下图是当点击span元素区域是,三个点击事件都会被触发,先后顺序是怎样的呢?
<div onclick="func1"> <p onclick="func2"> <span onclick=""func3> </span> </p> </div>
两种模型
对于这个事件的处理顺序上,Netscape和微软有两种截然不同的处理方法
•Netscape主张事件会从最外层开始发生,直到最具体的元素,这种事件发生顺序被称为捕获型
•微软则保持事件从最内部元素开始发生,然后一直向上传播,这种事件顺序被称为冒泡型
这两种事件顺序是截然相反的。Explorer浏览器只支持冒泡事件,Mozilla,Opera7和Konqueror两者都支持。而更古老的opera和iCab两者都不支持
w3c
任何发生在w3c事件模型中的事件,首是进入捕获阶段,直到达到目标元素,再进入冒泡阶段。
对于正常的web开发,可以选择是在捕获阶段还是冒泡阶段绑定事件处理函数,这是通过addEventListener()方法实现的,如果这个函数的useCapture参数是true,则在捕获阶段绑定函数,反之false,在冒泡阶段绑定函数。
element.addEventListener(event, function, useCapture)
阻止冒泡
在正常的开发过程中,如果想要阻止事件的传播,通过一个方法实现。
在微软的模型中,你必须设置事件的cancelBubble的属性为true
window.event.cancelBubble = true
在w3c模型中你必须调用事件的sPropagation()方法
e.sPropagation()
通过调用这些方法会阻止所有冒泡向外传播。跨浏览器解决方案
function doSomething(e) { if (!e) { var e = window.event; e.cancelBubble = true; } if (e.sPropagation) { e.sPropagation(); } }
以上这篇深入理解事件冒泡(Bubble)和事件捕捉(capture)就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程