【前端每天一题】🔥第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()

相关推荐
QQ1__81151751519 分钟前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态21 分钟前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子22 分钟前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室24 分钟前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI24 分钟前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing24 分钟前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者24 分钟前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册24 分钟前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李27 分钟前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢29 分钟前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web