JS Event Propagation (bubbling and capture)

事件传播是双向的(bidirectional), 先从DOM树的根元素(window)到事件目标元素(event target), 接着从事件事件目标元素回到DOM树的根元素. 整体可以分为下面三个阶段:

  • 从根元素到事件目标父元素: 称之为事件捕获阶段(event capture phase)
  • 事件目标自己: 称之为目标阶段(target phase)
  • 从目标父元素到根元素: 称之为事件冒泡阶段(event bubble phase)

在这里插入图片描述

  • Capture Phase
    • el.addEventListener(‘click’, listener, true)
    • Target Phase
  • Bubble Phase
    • el.addEventListener(‘click’, listener, false)
    • el.addEventListener(‘click’, listener) // 第三个参数默认是false

Note: 某些事件比如 blur, focus, load 不会在冒泡阶段(bubble phase)出现, 也就是说这些事件只会在捕获阶段(capture phase)被捕获, 因此在这些事件控制上, addEventListener 函数的第三个参数必须设定为 true 否则无法执行回调函数.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值