[js电子榨菜]事件传递机制 event propogate

(这篇文章可能图片会少一些,理解一下),毕竟这个币设备实在不太灵敏

其实在vue操作事件的时候,我们经常可以了解到一个"修饰"stop,官方给出的解释是阻止事件冒泡传递。冒泡传递其实值得是事件传递过程中的一个阶段(bubble)。

接下来将从js原生的角度讲解事件传递机制

1.propogate's phases

事件传播从生成,到对应dom全部执行对应的回调函数结束,一共是经过三个阶段

(1)capture

捕获阶段:捕获的意思是dom元素监听这个事件是否发生

事件最早创建以后,是在根dom上被优先监听到这个事件的存在,然后在dom树中完成向下传递

(2)target

目标阶段(我不知道这个翻译是否合理,总感觉有点怪)

目标阶段,事件自上而下传递,传递到发出该事件的dom元素以后,停止向下传递

(3)bubble

冒泡阶段,从targetDom开始,沿着dom树向上传递这个事件

对与target的双亲或者祖先来说,如果他们设置了对某个事件的监听,就会触发对应的回调函数

2.practive situation

可能这样有点难以理解,这样,我据个例子

复制代码
<div>  <button/>

</div>

比如说我们在div上放置一个点击事件的监听

然后我们点击一下button,首先会触发button的函数,然后才是div的回调

在capture阶段,就算事件确确实实经过了div(根据dom树的结构),也不会在这个阶段完成触发操作。而是在冒泡阶段,才会最终触发

而target则为一个中转点

3.一个可能要注意一些的问题

为什么要有target阶段:我的想法是为了严格去分"自上而下"和"自下而上"两个阶段,因为这两个阶段承担了完全不同的功能。有些时候我们会把target作为bubble的一部分,就是因为回调函数都是在这个阶段内进行执行的

如何判断当前是不是发起事件的dom元素?

在js里,事件同样是一个对象,event object。它会保留的一个属性就是哪个dom元素启动了这个事件。就可以判断何时进行target阶段

4.小结

捕获阶段是自上而下的过程,事件从文档根节点向下传播,依次经过目标元素的祖先元素,直到达到目标元素。在捕获阶段,事件的处理程序可以在祖先元素上被触发。

而冒泡阶段是自下而上的过程,事件从目标元素向上传播,依次经过目标元素的父元素、祖先元素,直到达到文档根节点。在冒泡阶段,事件的处理程序可以在目标元素的父元素和祖先元素上被触发。

在捕获阶段和冒泡阶段,如果在某个元素上绑定了相同类型的事件监听器,它们会按照它们在 DOM 中的顺序被触发。也就是说,先绑定的事件监听器会先被触发,后绑定的事件监听器会后被触发。

相关推荐
恋猫de小郭31 分钟前
Flutter 正在计划提供 Packaged AI Assets 的支持,让你的包/插件可以更好被 AI 理解和选择
android·前端·flutter
小小前端--可笑可笑35 分钟前
Vue / React 单页应用刷新 /login 无法访问问题分析
运维·前端·javascript·vue.js·nginx·react.js
小林敲代码77881 小时前
记一次 Vue 项目首屏优化:从 7.1s 到 0.9s,深挖 Gzip 的力量
前端·javascript·vue.js
前端大卫1 小时前
写给年轻程序员的几点小建议
前端
Highcharts.js2 小时前
什么是向量图表?如何用 Highcharts 快速创建一个笛卡尔坐标图/矢量图?
javascript·开发文档·highcharts·图表开发·向量图·矢量图表·笛卡尔坐标图
NEXT062 小时前
React 闭包陷阱深度解析:从词法作用域到快照渲染
前端·react.js·面试
脱离语言2 小时前
Jeecg3.8.2 前端经验汇总
开发语言·前端·javascript
NEXT063 小时前
useMemo 与 useCallback 的原理与最佳实践
前端·javascript·react.js
小爱丨同学3 小时前
React-Context用法汇总 +注意点
前端·javascript·react.js
徐同保4 小时前
python如何手动抛出异常
java·前端·python