阻止冒泡和阻止捕获
注意:现代所有的浏览器都支持事件冒泡,只是在实现上有一些差别
stopPropagation()方法既可以阻止事件冒泡,也可以阻止事件捕获,也可以阻止处于目标阶段。
DOM3新增: event.stopImmediatePropagation() :如果有多个相同类型事件的事件监听函数绑定到同一个元素,当该类型的事件触发时,它们会按照被添加的顺序执行。如果其中某个监听函数执行了 event.stopImmediatePropagation() 方法,则当前元素剩下的监听函数将不会被执行。
(注意区别 event.stopPropagation,共同点:阻止事件传播到父元素。区别:阻止 绑定在当前事件的同类事件的运行 )
参照: https://developer.mozilla.org/zh-CN/docs/Web/API/Event/stopImmediatePropagation
浏览器中事件的冒泡
点击p元素时,会触发p元素和div元素的2个事件,所以会运行两次handler,点击span,会触发div的事件,所以会运行div绑定的handler如果要避免,你可以搜索一下Javascript事件冒泡
当事件( event )触发在某个元素上时,如果这个事件绑定了方法那么这个方法会被执行,如果没有绑定方法或者被绑定的方法返回 true ,那么这个事件会向其父级传播,一层一层直到最顶层即 document 或者 window ,除非被认为的中断。
现代浏览器的冒泡机制基本一致,事件都是由最内层的元素网最外层元素冒泡,冒泡顺序:child->paren->body->html->document->window。可能早期浏览器(IE5、IE6等)有所区别。
事件的捕获刚好和冒泡的方向相反,由最外层开始捕获,然后到最内层,捕获顺序:window->document->html->body->paren->child。
事件捕获优先发生而冒泡后发生,这样一来从捕获到冒泡形成了一组事件流。
通过 addEventListener(event,fn,useCapture) 这个方法给 DOM 绑定事件时,前两个参数很容易理解一个是事件名称 event ,第二个是触发方法 fn ,其中第三个参数是一个 bool 值,用来设置绑定的方法是在事件捕获(true)时执行还是冒泡(false)时执行,一般我们会设置 false,这样比较安全。
通常情况下,我们不会去做阻止事件冒泡的事情,但是有时候当我们不想同时执行绑定在两个 DOM 元素上的事件时,我们需要手动的阻止事件的冒泡,通常我们使用如下几种方式来阻止:
默认事件:该元素默认执行的动作。例如:button 的默认事件是 submit,a 的默认事件是打开链接 等等
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!