【前端每天一题】🔥第7题 事件冒泡与事件捕获 - 前端高频面试题

这是前端高频面试题的详细版 + 速记卡版,可以直接用在面试里。

第 7 题:事件冒泡和事件捕获的区别?如何阻止事件冒泡?如何阻止默认行为?


一、事件冒泡(Event Bubbling)是什么?

事件从 最内层元素(target) 一直向 外层父级元素 传播,直到最顶层(document)。

传播顺序:

javascript 复制代码
target → parent → document

示例:

HTML:

html 复制代码
<div id="outer">
  <div id="inner"></div>
</div>

点击 inner 时,顺序是:

sql 复制代码
inner → outer → document

冒泡是浏览器默认的事件传播机制。


二、事件捕获(Event Capturing)是什么?

事件从 最外层(document)目标元素(target) 方向传播。

传播顺序:

javascript 复制代码
document → parent → target

三、浏览器完整的事件流阶段

事件流包含 三个阶段

markdown 复制代码
1. 捕获阶段(从外到内)
2. 目标阶段(target 本身)
3. 冒泡阶段(从内到外)

图示:

javascript 复制代码
document
   ↓ (捕获)
parent
   ↓
target
   ↑ (冒泡)
parent
   ↑
document

四、addEventListener 如何指定阶段?

语法:

javascript 复制代码
element.addEventListener(event, handler, useCapture)

第三个参数:

  • true → 捕获阶段执行
  • false → 冒泡阶段执行(默认)

示例:

javascript 复制代码
div.addEventListener('click', handler, true)  // 捕获
div.addEventListener('click', handler, false) // 冒泡

五、如何阻止事件冒泡?

方式 1:标准方法(推荐)

javascript 复制代码
event.stopPropagation()

方式 2:阻止所有传播(包括捕获 + 冒泡)

javascript 复制代码
event.stopImmediatePropagation()

⚠️ 并且会阻止"同一元素上后续绑定的回调函数"。

🚫 重要说明:return false 并不会阻止冒泡

原生 DOM 中:

javascript 复制代码
return false

只能阻止默认行为,不会阻止冒泡。

(除非在 jQuery 中)


六、如何阻止默认行为?

方法 1:标准方法

javascript 复制代码
event.preventDefault()

方法 2:在标签内直接 return false(只阻止默认行为)

html 复制代码
<a href="#" onclick="return false">点击</a>

方法 3:表单中阻止提交

javascript 复制代码
form.addEventListener("submit", e => e.preventDefault())

七、快速对比总结表

行为 方法 作用
阻止冒泡 event.stopPropagation() 阻止事件向父级继续冒泡
阻止所有传播 event.stopImmediatePropagation() 同节点后续事件也不再触发
阻止默认行为 event.preventDefault() 阻止浏览器的默认动作(跳转、滚动、提交等)
return false 部分情况下等于 preventDefault 原生不会阻止冒泡

速记卡(10 秒复习版)

🔶 捕获:从外到内

document → ... → target

🔶 冒泡:从内到外

target → ... → document

🔶 阻止冒泡

event.stopPropagation()

🔶 阻止所有传播(包括同级绑定事件)

event.stopImmediatePropagation()

🔶 阻止默认行为

event.preventDefault()

相关推荐
0思必得04 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5165 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino5 小时前
图片、文件的预览
前端·javascript
测试涛叔6 小时前
金三银四软件测试面试题(800道)
软件测试·面试·职场和发展
layman05287 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔7 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李7 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN7 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒7 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库7 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css