news 2026/5/26 7:14:03

Vue 事件机制全面解析:原生事件、自定义事件与 DOM 冒泡完全讲透

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue 事件机制全面解析:原生事件、自定义事件与 DOM 冒泡完全讲透

文章目录

  • Vue 事件机制全面解析:原生事件、自定义事件与 DOM 冒泡完全讲透
  • 1.Vue事件的核心机制
    • 1.1 原生事件(native events)
    • 1.2 子组件自定义事件(子组件 emit)
    • 1.3 浏览器 DOM 的事件冒泡机制
  • 2.事件相关的实用补充
    • 2.4 DOM 常用事件
    • 2.5 Vue 事件修饰符总览

Vue 事件机制全面解析:原生事件、自定义事件与 DOM 冒泡完全讲透

为什么要理解 Vue 事件?

  • 只知道 @click,却分不清它属于谁

  • 子组件不 emit,父组件 @click 为何能触发?

  • 面试中被问 “emit 和 @click 区别?

1.Vue事件的核心机制

1.1 原生事件(native events)

当 @drop 写在 HTML 原生标签上,例如:

<div @drop="handleDrop"></div>

这说明:

  • 监听的是浏览器 DOM 的 drop 事件
  • 用户把文件拖到 上时触发
  • 不需要任何子组件 emit

示例如下:

<divclass="chunk-upload-trigger"@drop="handleDrop"@dragenter="handleDragEnter"@dragleave="handleDragLeave">

这些都是原生 DOM 事件,没有任何“子组件触发”的概念

1.2 子组件自定义事件(子组件 emit)

父组件中写入:

<Child@file-selected="onFileSelected"/>

等待子组件 Child 调用

emit('file-selected',file)

父组件收到这个事件并执行 onFileSelected

  • ChunkUploadTrigger 内部 emit(‘file-selected’, file)
  • UploadPanel 接收到
  • 执行 handleFileSelected

这种完全不涉及 DOM 事件。

1.3 浏览器 DOM 的事件冒泡机制

父组件中

<ChunkUploadTrigger @drop="handleDrop" />

子组件中

<div @drop="handleDropInside"></div>

子组件不用 emit 通知父组件,子组件父组件都是同名的事件,此时父组件的事件就会穿透绑定到子组件根元素,两者的执行顺序,childDrop() 会触发,parentDrop() 也会触发,两者触发顺序按 DOM 事件流来(冒泡顺序)

DOM 事件冒泡不关心你是不是在一个文件、一个组件,它只关心 DOM 节点树。

父组件根 DOM └── 子组件根 DOM └── 子组件内部 DOM

所以虽然写在了两个.vue 文件,但是渲染出来的其实是跟在一个文件里写了两个 父子div 没有任何区别,事件冒泡就是沿着这棵 DOM 树往上走的

<Parent> <ChunkUploadTrigger /> </Parent> <div class="parent-root"> <div class="chunk-upload-trigger"> ← 子组件根节点 <div>...</div> </div> </div>

2.事件相关的实用补充

2.4 DOM 常用事件

浏览器原生事件,放在 HTML 标签上就能触发

鼠标事件

click,dblclick,mousedown,mouseup

键盘事件

keydown,keyup,keypress

输入 & 表单事件

dragenter,dragover,dragleave,drop

其他 DOM 事件

scroll,wheel,resize,load,error

2.5 Vue 事件修饰符总览

修饰符含义对应的 DOM 行为
.stop阻止事件冒泡event.stopPropagation()
.prevent阻止默认行为event.preventDefault()
.capture使用捕获模式addEventListener(…, true)
.self只有事件目标是当前元素时触发event.target === currentTarget
.once事件只触发一次自动 removeEventListener
.passive表示监听器不会调用 preventDefaultpassive: true

比如:

@dragover.prevent="handleDragOver"
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/26 6:39:06

IfcOpenShell如何解决传统BIM工作流中的五大痛点?

在传统BIM项目中&#xff0c;设计师常常面临数据孤岛、格式兼容性差、工具链断裂等挑战。IfcOpenShell作为开源IFC库和几何引擎&#xff0c;通过模块化架构重新定义了BIM数据处理方式。不同于传统的单一工具链&#xff0c;它提供了一套完整的解决方案&#xff0c;让BIM协作变得…

作者头像 李华
网站建设 2026/5/25 16:37:51

5步构建Android视频播放器跨设备适配框架

5步构建Android视频播放器跨设备适配框架 【免费下载链接】ExoPlayer 项目地址: https://gitcode.com/gh_mirrors/ex/ExoPlayer 在移动应用开发领域&#xff0c;视频播放功能的多设备兼容性始终是技术团队面临的重大挑战。随着Android设备生态的碎片化程度不断加深&…

作者头像 李华
网站建设 2026/5/25 18:39:41

计算机专业大学生学网络安全:先学这 5 个方向,校招不踩坑

大学生学安全&#xff1a;先学这 5 个方向&#xff0c;校招不踩坑 “大一学 Nmap 扫端口&#xff0c;大二学 Burp 抓包&#xff0c;大三还在刷 CTF 题&#xff0c;临毕业发现简历上只有‘会用 XX 工具’&#xff0c;面试被问‘能解决什么实际问题’哑口无言”—— 这是多数大学…

作者头像 李华
网站建设 2026/5/26 0:32:52

给你规划大学四年任务,毕业即可从事网络安全工程师

前言 最近有很多小伙伴问我&#xff1a;零基础如何入门网络安全&#xff0c;他的梦想是成为网络安全工程师。我一问年龄&#xff1a;也就刚刚步入大一&#xff0c;这可是最好的时机&#xff0c;因为有足足四年的时光来做准备。 行业前景 网络安全行业的前景相信已经无须多言&a…

作者头像 李华
网站建设 2026/5/26 6:34:19

3步掌握MuJoCo无头渲染:云端服务器批量仿真可视化终极指南

3步掌握MuJoCo无头渲染&#xff1a;云端服务器批量仿真可视化终极指南 【免费下载链接】mujoco Multi-Joint dynamics with Contact. A general purpose physics simulator. 项目地址: https://gitcode.com/GitHub_Trending/mu/mujoco 在云端服务器环境运行物理仿真时&a…

作者头像 李华
网站建设 2026/5/25 18:40:18

Unpaywall浏览器扩展:如何快速解锁付费学术论文

Unpaywall浏览器扩展&#xff1a;如何快速解锁付费学术论文 【免费下载链接】unpaywall-extension Firefox/Chrome extension that gives you a link to a free PDF when you view scholarly articles 项目地址: https://gitcode.com/gh_mirrors/un/unpaywall-extension …

作者头像 李华