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

相关推荐
沙振宇3 分钟前
【Web】使用Vue3+PlayCanvas开发3D游戏(六)模拟自驾场景SR+3D可视化
前端·游戏·3d·vue3·playcanvas
吴所畏惧9 分钟前
前端打包cdn或者dll打包方式
前端
小鲤鱼ya13 分钟前
vue3 + ts + uni-app 移动端封装图片上传添加水印
前端·typescript·uni-app·vue3
霍理迪14 分钟前
Vue—条件渲染与循环渲染
前端·javascript·vue.js
前端摸鱼匠15 分钟前
面试题3:自注意力机制(Self-Attention)的计算流程是什么?
人工智能·ai·面试·职场和发展
xixixin_18 分钟前
【CSS】字体大小不一致?px与vw渲染差异的底层原理与解决方案
前端·css
小J听不清23 分钟前
CSS 内边距(padding)全解析:取值规则 + 表格实战
前端·javascript·css·html·css3
zhangjikuan8925 分钟前
在 ArkTS 中,Promise 的使用比 TypeScript 更严格(必须显式指定泛型类型)
前端·javascript·typescript
桐溪漂流25 分钟前
Uni-app H5 环境下 ResizeObserver 监听 mp-html 动态高度
前端·uni-app·html
前端摸鱼匠25 分钟前
大模型面试题1:简述大模型(LLM)的定义,与传统NLP模型的核心区别是什么?
人工智能·ai·语言模型·自然语言处理·面试·职场和发展