JavaScript事件流机制详解:捕获、冒泡与阻止传播

JavaScript事件流机制详解:捕获、冒泡与阻止传播

事件流概念

事件流描述的是事件在DOM结构中传播的路径和顺序。当DOM元素触发事件时,事件会经历三个阶段:

  1. 捕获阶段:从window对象向下传播到目标元素
  2. 目标阶段:事件到达目标元素
  3. 冒泡阶段:从目标元素向上传播回window对象
html 复制代码
<div class="grandparent">
  <div class="parent">
    <div class="child">点击我</div>
  </div>
</div>

事件捕获

事件捕获是从最外层祖先元素开始,逐级向下传播到目标元素的过程:

javascript 复制代码
document.querySelector('.grandparent').addEventListener('click', () => {
  console.log('祖父元素捕获');
}, true); // 第三个参数true表示捕获阶段触发

document.querySelector('.parent').addEventListener('click', () => {
  console.log('父元素捕获');
}, true);

document.querySelector('.child').addEventListener('click', () => {
  console.log('子元素目标');
}, true);

点击子元素时输出顺序:

复制代码
祖父元素捕获
父元素捕获
子元素目标

事件冒泡

事件冒泡是默认行为,从目标元素向上传播到祖先元素:

javascript 复制代码
document.querySelector('.grandparent').addEventListener('click', () => {
  console.log('祖父元素冒泡');
}); // 默认false,冒泡阶段触发

document.querySelector('.parent').addEventListener('click', () => {
  console.log('父元素冒泡');
});

document.querySelector('.child').addEventListener('click', () => {
  console.log('子元素目标');
});

点击子元素时输出顺序:

复制代码
子元素目标
父元素冒泡
祖父元素冒泡

阻止事件冒泡

使用event.stopPropagation()可以阻止事件继续传播:

javascript 复制代码
document.querySelector('.child').addEventListener('click', (e) => {
  console.log('子元素点击');
  e.stopPropagation(); // 阻止冒泡
});

document.querySelector('.parent').addEventListener('click', () => {
  console.log('这行不会执行');
});

实际应用案例

事件委托:利用冒泡机制在父元素上统一处理子元素事件

javascript 复制代码
document.querySelector('ul').addEventListener('click', (e) => {
  if(e.target.tagName === 'LI') {
    console.log('点击了列表项:', e.target.textContent);
  }
});
相关推荐
在水一缸4 分钟前
重塑前端开发认知:当 AI 遇见 HTML 的“不合理有效性”
前端·人工智能·html·ai编程·claude·前端开发
SwJieJie9 分钟前
Webpack vs Vite 构建工程化实战(Vue 项目深度解析)
前端·vue.js·webpack·node.js
swg32132117 分钟前
Redis实现主从选举
java·前端·redis
英俊潇洒美少年20 分钟前
前端核心性能指标全解(CWV三大指标+辅助指标、检测方式、优化、面试背诵)
前端
alexander06821 分钟前
JavaScript 中,对象内部函数的几种等价写法,对象外部的 几种等价写法
javascript
云水一下22 分钟前
Vue.js从零到精通系列(八):项目实战——构建一个完整的电商后台管理系统
前端·javascript·vue.js
Csvn22 分钟前
Vue3 响应式陷阱:解构赋值后页面不动了?Proxy 的"隐形成员"在搞鬼
前端·vue.js
LAM LAB28 分钟前
【Web】网页如何模拟移动端获取定位\定位模拟测试
开发语言·前端·javascript
yunceqing30 分钟前
从Excel调度到TMS平台:物流软件开发避坑清单
大数据·前端·网络·人工智能·excel·推荐算法
IT_陈寒31 分钟前
Redis主从切换把我坑惨了,这份血泪史你最好看看
前端·人工智能·后端