news 2025/12/28 6:51:24

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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/24 2:59:51

揭秘MCP服务发现:构建智能AI工具生态系统的核心技术

揭秘MCP服务发现&#xff1a;构建智能AI工具生态系统的核心技术 【免费下载链接】awesome-mcp-servers A collection of MCP servers. 项目地址: https://gitcode.com/GitHub_Trending/aweso/awesome-mcp-servers 在AI助手快速发展的今天&#xff0c;如何让AI模型安全高…

作者头像 李华
网站建设 2025/12/24 18:38:17

智能笔记管理:如何高效组织你的每日任务与灵感

智能笔记管理&#xff1a;如何高效组织你的每日任务与灵感 【免费下载链接】DailyNotes App for taking notes and tracking tasks on a daily basis 项目地址: https://gitcode.com/gh_mirrors/da/DailyNotes 每天面对繁杂的任务和零散的灵感&#xff0c;你是否也曾感到…

作者头像 李华
网站建设 2025/12/23 2:31:06

终极指南:如何快速掌握 My Mind 免费在线思维导图工具

终极指南&#xff1a;如何快速掌握 My Mind 免费在线思维导图工具 【免费下载链接】my-mind Online Mindmapping Software 项目地址: https://gitcode.com/gh_mirrors/my/my-mind My Mind 是一款功能强大的免费在线思维导图应用&#xff0c;专为需要高效整理思维的用户设…

作者头像 李华
网站建设 2025/12/24 21:22:18

Vim插件管理器VAM终极指南:从零开始构建高效开发环境

作为一名Vim用户&#xff0c;你是否曾经为插件管理而烦恼&#xff1f;插件依赖冲突、手动更新困难、启动速度缓慢……这些痛点正在阻碍你享受Vim带来的高效开发体验。今天&#xff0c;让我们一起来探索Vim插件管理器VAM&#xff0c;这款能够彻底改变你Vim使用方式的强大工具。 …

作者头像 李华
网站建设 2025/12/25 18:45:49

AgentWeb终极指南:Android混合开发的一站式解决方案

AgentWeb终极指南&#xff1a;Android混合开发的一站式解决方案 【免费下载链接】AgentWeb AgentWeb is a powerful library based on Android WebView. 项目地址: https://gitcode.com/gh_mirrors/ag/AgentWeb 还在为Android应用中WebView与原生组件的割裂体验而烦恼吗…

作者头像 李华