在JavaScript / HTML中,事件监听的捕获和冒泡阶段解析

在 JavaScript 中,事件传播分为三个阶段:捕获阶段(Capture Phase)目标阶段(Target Phase)冒泡阶段(Bubble Phase)addEventListener 的第三个参数可以控制事件监听器是在捕获阶段还是冒泡阶段触发。

1. 捕获阶段(Capture Phase)

  • 从外向内传播 :事件从最外层的祖先元素(window)向下逐级传递到目标元素。
  • 监听方式 :将 addEventListener 的第三个参数设为 true{ capture: true }
  • 特点:先执行捕获阶段的监听器,再执行目标阶段的事件,最后执行冒泡阶段的监听器。

2. 冒泡阶段(Bubble Phase)

  • 从内向外传播:事件从目标元素向上逐级传递到最外层的祖先元素。
  • 默认行为 :如果 addEventListener 的第三个参数未设置或设为 false/{ capture: false },监听器会在冒泡阶段触发。
  • 特点 :大多数事件默认支持冒泡(如 click),但少数事件(如 focus)不冒泡。

区别总结

特征 捕获阶段 冒泡阶段
传播方向 外层 → 目标元素(向下) 目标元素 → 外层(向上)
addEventListener 第三个参数设为 true 第三个参数为 false(默认)
执行顺序 先于冒泡阶段 后于捕获阶段
常见用途 提前拦截事件(如权限检查) 常规事件处理(如委托)

代码示例

html 复制代码
<div id="parent">
  <div id="child">点击我</div>
</div>

<script>
  const parent = document.getElementById('parent');
  const child = document.getElementById('child');

  // 捕获阶段监听(第三个参数为 true)
  parent.addEventListener('click', () => {
    console.log('父元素 - 捕获阶段');
  }, true);

  // 冒泡阶段监听(默认)
  parent.addEventListener('click', () => {
    console.log('父元素 - 冒泡阶段');
  });

  child.addEventListener('click', () => {
    console.log('子元素 - 目标阶段');
  });
</script>

输出结果(点击子元素时):

复制代码
父元素 - 捕获阶段
子元素 - 目标阶段
父元素 - 冒泡阶段

应用场景

  1. 事件委托(冒泡阶段)
    通过父元素监听子元素的事件(如动态生成的列表项)。
  2. 拦截操作(捕获阶段)
    在事件到达目标前进行拦截(如权限验证、阻止默认行为)。

注意事项

  • 使用 event.stopPropagation() 可阻止事件继续传播(捕获或冒泡)。
  • 目标元素的事件监听器(如 child)在目标阶段触发,与第三个参数无关。
相关推荐
Mr Xu_2 分钟前
Vue 3 中计算属性的最佳实践:提升可读性、可维护性与性能
前端·javascript
lly2024063 分钟前
《堆的 shift down》
开发语言
子兮曰17 分钟前
深入理解滑块验证码:那些你不知道的防破解机制
前端·javascript·canvas
Highcharts.js20 分钟前
【Highcharts】如何用命令行渲染导出图片?
javascript·导出·开发文档·highcharts·命令行渲染·命令行功能
黎雁·泠崖23 分钟前
【魔法森林冒险】2/14 抽象层设计:Figure/Person类(所有角色的基石)
java·开发语言
季明洵1 小时前
C语言实现单链表
c语言·开发语言·数据结构·算法·链表
墨雪不会编程1 小时前
C++之【深入理解Vector】三部曲最终章
开发语言·c++
浅念-1 小时前
C语言编译与链接全流程:从源码到可执行程序的幕后之旅
c语言·开发语言·数据结构·经验分享·笔记·学习·算法
陈振wx:zchen20081 小时前
JavaScript
javascript·js
小宋10211 小时前
Java 项目结构 vs Python 项目结构:如何快速搭一个可跑项目
java·开发语言·python