DOM: EVENT FLOW
2024-10-19 06:19:56
捕获阶段(capture phase)
捕获阶段的定义如下(w3c):The event object propagate through the target's ancestors from the defaultView to the target's parent.
事件对象在事件目标的祖先中上到下顺向传播,从最顶层的defaultView到事件目标的(直系)父元素。
捕获阶段发生在整个事件流动的开始。在这阶段里事件会从父(主干)到子(分支)由上往下传播,被元素一层层地捕获。
文章开头的例子里面,捕获阶段的click事件会依次在document、body、div上触发:
文章开头的例子里面,捕获阶段的click事件会依次在document、body、div上触发:
document 1
v
body 2
v
div 3
v
button
一般没太大需要监听捕获阶段的事件;如果确实希望这么做,需要将
addEventListener
的第三个参数设置为true:// 第三个参数设置是否为捕获阶段,默认为false
element.addEventListener('click', function() {}, true)
目标阶段(target phase)
目标阶段的定义是(w3c):The event object arrive at the event object's event target.事件对象到达事件目标。
例子里面,就是事件在button上触发的。addEventListener
可以监听目标阶段的事件:
element.addEventListener('click', function() {})
如果事件是不可冒泡的,那整个事件流动会到此为止,不会发生下面的冒泡阶段。
冒泡阶段(bubble phase)
冒泡阶段的定义(w3c):The event object propagates through the target's ancestors in reverse order, starting with the target's parent and ending with the defaultView.
事件对象会在事件目标的祖先元素里反向传播,由开始的父元素到最后的defaultView(document)。
冒泡阶段发生在最后,在这阶段里事件会从子(分支)到父(主干)逆向传播,看起来像是一个水里的泡泡往上冒。
例子里面,冒泡阶段的click事件会依次在div、body、document上触发:
document 3
^
body 2
^
div 1
^
button
"bubbles"
Event下的bubbles属性标明该事件是否为可冒泡的。一旦该值为false,则说明 evnet不可冒泡,那其流动也会在第二阶段“目标阶段”后就终止。
摘自:
作者:butterandfly
链接:https://www.jianshu.com/p/382895a4027d
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处
作者:butterandfly
链接:https://www.jianshu.com/p/382895a4027d
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处
最新文章
- C 标准库系列之errno.h
- Mysql主从复制,读写分离(mysql-proxy),双主结构完整构建过程
- CSS div水平垂直居中和div置于底部
- CRM 2016 js 奇怪现象
- 在Myeclipse buildpath 加server lib
- STM32 IAP 在线更新程序 为什么有时行 有时又不行 感觉不可靠 问题解决
- 9.28noip模拟试题
- 搜索(四分树):BZOJ 4513 [SDOI2016 Round1] 储能表
- 我的eclipse插件推荐
- VDI转vmdk(VirtualBox与VMware硬盘格式转换)[转]
- String[255]在高版本Delphi里还是被解释成Byte,总体长度256,使用StrPCopy可以给Array String拷贝字符串(内含许多实验测试)
- NYoj 685 查找字符串
- ArcGIS License启动无响应
- SAP 没有激活HUM功能照常可以使用Handling Unit
- shell脚本学习之case用法及实例
- 使用TkbmMWThreadList实现线程安全列表
- Ubuntu14.04 使用本地摄像头跑ORB SLAM2(暂未完成)
- python中的深拷贝和浅拷贝
- 【vue】中 $listeners 的使用方法
- 180425、cookie工具类
热门文章
- 在Ubuntu中启动./jmeter-server报错Server failed to start: java.rmi.RemoteException: Cannot start. ranxf is a loopback address.解决方法
- Linux Java环境搭建
- Windos 系统网络连接 调优
- cordova 插件
- 在父页面访问iframe的东西
- 20145321 《Java程序设计》第2周学习总结
- 修改Linux登录提示信息
- SaltStack匹配target-第六篇
- mybatis缓存有关的设置和属性
- python sort dict 总结