美文网首页前端技术前端知识
浏览器中事件的冒泡

浏览器中事件的冒泡

作者: 一俢 | 来源:发表于2019-02-06 09:15 被阅读48次

什么是事件冒泡

当事件(event)触发在某个元素上时,如果这个事件绑定了方法那么这个方法会被执行,如果没有绑定方法或者被绑定的方法返回true,那么这个事件会向其父级传播,一层一层直到最顶层即document或者window,除非被认为的中断。

冒泡机制

现代浏览器的冒泡机制基本一致,事件都是由最内层的元素网最外层元素冒泡,冒泡顺序:child->paren->body->html->document->window。可能早期浏览器(IE5、IE6等)有所区别。

事件捕获

事件的捕获刚好和冒泡的方向相反,由最外层开始捕获,然后到最内层,捕获顺序:window->document->html->body->paren->child。

DOM 的事件流

事件捕获优先发生而冒泡后发生,这样一来从捕获到冒泡形成了一组事件流。

通过addEventListener(event,fn,useCapture)这个方法给 DOM 绑定事件时,前两个参数很容易理解一个是事件名称event,第二个是触发方法fn,其中第三个参数是一个 bool 值,用来设置绑定的方法是在事件捕获(true)时执行还是冒泡(false)时执行,一般我们会设置 false,这样比较安全。

event-bubble.png

阻止事件冒泡

通常情况下,我们不会去做阻止事件冒泡的事情,但是有时候当我们不想同时执行绑定在两个 DOM 元素上的事件时,我们需要手动的阻止事件的冒泡,通常我们使用如下几种方式来阻止:

  • return false:阻止默认事件和冒泡事件;
  • event.preventDefault():阻止默认事件但是允许冒泡事件;
  • event.stopPropagation():阻止冒泡但是允许默认事件;

默认事件:该元素默认执行的动作。例如:button 的默认事件是 submit,a 的默认事件是打开链接 等等

相关文章

  • Javascript事件笔记

    事件在DOM结构中传播的顺序叫事件流,分三个阶段:事件捕获、事件发生、事件冒泡 现代浏览器事件冒泡一直冒到wind...

  • 冒泡和捕获

    ​在浏览器中,事件的传播方式分为:事件冒泡和事件捕获。那么事件冒泡和事件捕获分别是什么?为什么会出现两种传播方式呢...

  • 阻止浏览器事件冒泡

    不同的浏览器对事件的解析机制不同,所以就会触发不同的事件,影响我们操作,如何取解决浏览器事件冒泡 ,所谓的事件冒泡...

  • JS事件的冒泡捕获--发生了什么

    多次遇到事件冒泡与捕获相关的题目,冒泡和捕获机制在不同浏览器中的兼容性也不相同,IE中默认只支持冒泡机制,冒泡和捕...

  • js事件流

    一:事件冒泡和事件代理事件:事件是文档和浏览器窗口中发生特定交互的瞬间,当我们与浏览器中的web页面进行某些类型交...

  • 浏览器中事件的冒泡

    什么是事件冒泡 当事件(event)触发在某个元素上时,如果这个事件绑定了方法那么这个方法会被执行,如果没有绑定方...

  • 前端系统学习 3. 浏览器相关

    1. 浏览器事件模型 事件的捕获和冒泡 addEventListener & removeEventListene...

  • DOM事件流

    DOM事件流 事件冒泡:浏览器的冒泡机制,当我们触发了元素的某个事件之后,它会首先执行,绑定在这个事件的函数,然后...

  • 11-3答辩

    1什么是事件流 事件传播的顺序对应浏览器的两种事件流模型:捕获型事件流和冒泡型事件流。冒泡型事件流:事件的传播是从...

  • 阻止冒泡和阻止捕获

    注意:现代所有的浏览器都支持事件冒泡,只是在实现上有一些差别 阻止事件冒泡捕获: stopPropagation(...

网友评论

    本文标题:浏览器中事件的冒泡

    本文链接:https://www.haomeiwen.com/subject/fxbbsqtx.html