本文实例分析了javascript事件捕获机制。分享给大家供大家参考,具体如下:
1.什么是事件冒泡?
在排序算法中,我们学过冒泡排序法,所谓冒泡就是让底层的东西浮出水面,对于事件冒泡也同样是如此,
下面我们来看一个例子来说明什么是事件冒泡。
<div> <button>测试</button> </div> <script> $("div").bind("click",function(){alert("div")}); $("button").bind("click",function(){alert("button"}); </script>
当支持事件冒泡时,当我们点击"测试”按钮时,首先会执行的是alert("button"),固名思意:
事件按照从最特定的事件目标到最不特定的事件目标(document对象)的顺序触发。
当div,button,html根元素都有事件时,事件执行的顺序为:
button->div->html
2.什么是事件捕获?
我们再来看事件捕获,相对于事件捕获,处理时间的顺序与事件冒泡截然相反,同样:
<div> <button>测试</button> </div> <script> $("div").bind("click",function(){alert("div")}); $("button").bind("click",function(){alert("button"}); </script>
执行这段代码,首先会alert("div"),其次会alert("button")。我们明确事件捕获的概念:
事件从最不精确的对象(document 对象)开始触发,然后到最精确。
同样的如果button,div,html元素上都有绑定事件,那么事件的实行顺序为:
html->div->button
3.各个版本的浏览器对事件的处理机制?
(1)在DOM中,即支持事件冒泡,也支持事件捕获,在W3C的标准中,认为任何事件都是从事件捕获出发,找到最终的结点,此后再进行冒泡,会到根结点。
DOM中支持事件绑定的函数为:
addEventListener("事件名",函数,userCapture);
对于userCapture参数,默认为false,支持事件冒泡。
若在userCapture参数,为true时,支持事件捕获。
(2)对于很多浏览器,都支持addEventListener方法,但是IE不支持!
(3) IE中的事件处理机制,IE中只支持事件冒泡,IE中有一个独有的事件绑定方法
attachEvent方法,此方法有两个参数:
attachEvent("事件名","函数名")
4.如何阻止事件的传播?
无论是事件冒泡还是事件捕获都是可以阻止的。
(1)首先在W3C中阻止事件的传播方法为:stopPropagation(),在IE中,通过设置
cancelBubble=true;
(2) 如何阻止事件的默认行为?在W3C标准中,使用preventDefault方法,在IE中通过设置
window.event.returnValue = false;
PS:关于javascript常用事件及相关说明还可参考本站在线工具:
javascript事件与功能说明大全:
http://tools.jb51.net/table/javascript_event
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript事件相关操作与技巧大全》、《JavaScript时间与日期操作技巧总结》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
本文向大家介绍深入解析JavaScript框架Backbone.js中的事件机制,包括了深入解析JavaScript框架Backbone.js中的事件机制的使用技巧和注意事项,需要的朋友参考一下 事件模型及其原理 Backbone.Events就是事件实现的核心,它可以让对象拥有事件能力 对象通过listenTo侦听其他对象,通过trigger触发事件。可以脱离Backbone的MVC,在自定义的
本文向大家介绍深入分析原生JavaScript事件,包括了深入分析原生JavaScript事件的使用技巧和注意事项,需要的朋友参考一下 JQuery这种Write Less Do More的框架,用多了难免会对原生js眼高手低。 小菜其实不想写这篇博客,貌似很初级的样子,但是看到网络上连原生js事件绑定和解除都说不明白,还是决定科普一下了。 首先声明,小菜懂的也不是很多,只是
本文向大家介绍浅析JavaScript中的事件机制,包括了浅析JavaScript中的事件机制的使用技巧和注意事项,需要的朋友参考一下 事件是什么 ? JavaScript与HTML交互是通过在用户或浏览器操纵页面上发生的事件进行处理。 当页面加载,这是一个事件。当用户点击一个按钮,这一下,也就是一个事件。事件的另一个例子是类似按下任意键,关闭窗口,调整窗口等。 开发者可以使用这些事件执行Jav
本文向大家介绍浅谈javascript中的事件冒泡和事件捕获,包括了浅谈javascript中的事件冒泡和事件捕获的使用技巧和注意事项,需要的朋友参考一下 1.事件冒泡 IE 的事件流叫做事件冒泡(event bubbling),即事件开始时由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播到较为不具体的节点(文档)。以下面的HTML 页面为例: 如果你单击了页面中的<div
本文向大家介绍js事件监听机制(事件捕获)总结,包括了js事件监听机制(事件捕获)总结的使用技巧和注意事项,需要的朋友参考一下 在前端开发过程中我们经常会遇到给页面元素添加事件的问题,添加事件的js方法也很多,有直接加到页面结构上的,有使用一些js事件监听的方法,由于各个浏览器对事件冒泡事件监听的机制不同,le浏览器只有事件冒泡,没有事件监听的机制,对于事件监听的兼容性问题是最大的难题: 1.直接
主要内容:事件捕获,事件冒泡,阻止事件捕获和冒泡,阻止默认操作在 JavaScript 中,我们将事件发生的顺序称为“事件流”,当我们触发某个事件时,会发生一些列的连锁反应,例如有如下所示的一段代码: 如果给每个标签都定义事件,当我们点击其中的 标签时,会发现绑定在 和 标签上的事件也被触发了,这到底是为什么呢?为了解答这一问题,微软和网景两公司提出了两种不同的概念,事件捕获与事件冒泡: 事件捕获:由微软公司提出,事件从文档根节点(Document 对象)流