javascript - 【事件冒泡】和【事件捕获】
2015-07-27 09:38
387 查看
冒泡型事件
微软提出的名为事件冒泡(event
bubbling)的事件流。事件会从最内层的元素开始发生,一直向上传播,直到document对象。事件按照从最特定的事件目标到最不特定的事件目标(document对象)的顺序触发。
捕获型事件
与事件冒泡相反,事件会从最外层开始发生,直到最具体的元素。事件从最不精确的对象(document 对象)开始触发,然后到最精确(也可以在窗口级别捕获事件,不过必须由开发人员特别指定)。
DOM事件流
同时支持两种事件模型:捕获型事件和冒泡型事件,但是,捕获型事件先发生。两种事件流会触及DOM中的所有对象,从document对象开始,也在document对象结束。
DOM事件模型最独特的性质是,文本节点也触发事件(在IE中不会)。
支持W3C标准的浏览器在添加事件时用
第一个参数是需要绑定的事件
第二个参数是触发事件后要执行的函数
而第三个参数默认值是false,表示在事件冒泡的阶段调用事件处理函数,如果参数为true,则表示在事件捕获阶段调用处理函数。
<html>
<body>
<ul id="layer_1">
<li id="layer_2">
<p id="layer_3">
<a id="layer_4">
Click_Me!
</a>
</p>
</li>
</ul>
<script>
var num1 = document.getElementById("layer_1");
var num2 = document.getElementById("layer_2");
var num3 = document.getElementById("layer_3");
var num4 = document.getElementById("layer_4");
num1.addEventListener("click",function(){alert("1");},false);//当第三个参数为false时,冒泡执行处理事件
num2.addEventListener("click",function(){alert("2");},false);
num3.addEventListener("click",function(){alert("3");},false);
num4.addEventListener("click",function(){alert("4");},false);
</script>
</body>
</html>执行结果为:4->3->2->1.
当false改为true
,执行结果正好相反:1->2->3->4.
微软提出的名为事件冒泡(event
bubbling)的事件流。事件会从最内层的元素开始发生,一直向上传播,直到document对象。事件按照从最特定的事件目标到最不特定的事件目标(document对象)的顺序触发。
捕获型事件
与事件冒泡相反,事件会从最外层开始发生,直到最具体的元素。事件从最不精确的对象(document 对象)开始触发,然后到最精确(也可以在窗口级别捕获事件,不过必须由开发人员特别指定)。
DOM事件流
同时支持两种事件模型:捕获型事件和冒泡型事件,但是,捕获型事件先发生。两种事件流会触及DOM中的所有对象,从document对象开始,也在document对象结束。
DOM事件模型最独特的性质是,文本节点也触发事件(在IE中不会)。
支持W3C标准的浏览器在添加事件时用
addEventListener(event,fn,useCapture);
第一个参数是需要绑定的事件
第二个参数是触发事件后要执行的函数
而第三个参数默认值是false,表示在事件冒泡的阶段调用事件处理函数,如果参数为true,则表示在事件捕获阶段调用处理函数。
<html>
<body>
<ul id="layer_1">
<li id="layer_2">
<p id="layer_3">
<a id="layer_4">
Click_Me!
</a>
</p>
</li>
</ul>
<script>
var num1 = document.getElementById("layer_1");
var num2 = document.getElementById("layer_2");
var num3 = document.getElementById("layer_3");
var num4 = document.getElementById("layer_4");
num1.addEventListener("click",function(){alert("1");},false);//当第三个参数为false时,冒泡执行处理事件
num2.addEventListener("click",function(){alert("2");},false);
num3.addEventListener("click",function(){alert("3");},false);
num4.addEventListener("click",function(){alert("4");},false);
</script>
</body>
</html>执行结果为:4->3->2->1.
当false改为true
,执行结果正好相反:1->2->3->4.
相关文章推荐
- JS实现冒泡排序,插入排序和快速排序(从input中获取内容)
- JS获取坐标
- JS 动态加载脚本的4种方法
- fastjson忽略某个属性
- js异步加载的三种解决方案
- js在方法Ajax请求数据来推断,验证无效(OnClientClick="return Method();"),或者直接运行的代码隐藏
- jsp <%%>java代码块获取<s:property的值
- html,js ,jsp工作学习
- javascript的事件总结
- WebGL是一种3D绘图标准,这种绘图技术标准允许把JavaScript和OpenGL ES 2.0结合在一起
- WebGL是一种3D绘图标准,这种绘图技术标准允许把JavaScript和OpenGL ES 2.0结合在一起
- JavaScript权威指南_142_第15章_脚本化文档_15.9-HTML表单-按钮
- JS闭包函数
- JavaScript权威指南_141_第15章_脚本化文档_15.9-HTML表单-表单和元素的的事件处理程序
- JavaScript权威指南_140_第15章_脚本化文档_15.9-HTML表单-表单和元素的属性
- 高德地图JavaScript API-控件
- Tab选项卡实现 javascript
- php实现向javascript传递数组的方法
- javascript通过获取html标签属性class实现多选项卡的方法
- JavaScript判断IE版本型号