news 2026/2/9 5:11:06

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/2/4 14:34:16

恶臭异味检测仪:金叶仪器实现异味精准识别与数据化管理

在当今社会&#xff0c;随着工业发展和城市化的推进&#xff0c;恶臭异味问题逐渐成为影响生活质量和环境健康的重要因素。恶臭气体通常来源于工业生产、污水处理、垃圾处理等多个领域&#xff0c;其不仅带来不适感&#xff0c;还可能对周边生态系统和人体健康产生潜在影响。因…

作者头像 李华
网站建设 2026/2/3 22:06:40

25年计算机专业大学生就业困难?不妨看看网络安全行业?

人才需求很明显的导致薪酬水平的变化。数据显示&#xff0c;网络安全领域的薪酬近年来稳步增长&#xff0c;2021年上半年&#xff0c;网络安全领域的平均招聘薪酬达到22387元/月&#xff0c;较去年同期提高了4.85%&#xff0c;相较于全行业的平均工资偏高。 很多公司希望通过招…

作者头像 李华
网站建设 2026/2/7 14:46:24

警惕!亚马逊新评级规则生效,粗放运营将直接出局

随着亚马逊对卖家账户评级体系的系统性重构&#xff0c;跨境卖家们正在经历一场深刻的运营逻辑变革&#xff0c;平台不再仅关心订单是否被妥投&#xff0c;而是将评估的目光穿透到店铺的每一个角落——从一张产品图片到一条客服回复&#xff0c;从包装的材质到碳足迹的追踪&…

作者头像 李华
网站建设 2026/2/4 22:21:59

串口查询方式发送/接收

HAL_UART_Transmit(&huart1,str,strlen(str),1000);参数&#xff1a;串口&#xff0c;要发送的字符数据&#xff0c;字符长度&#xff0c;等待时间HAL_UART_Receive(&huart1,&c,1,100);参数&#xff1a;串口种类&#xff0c;读取的数据保存到哪里&#xff0c;读取了…

作者头像 李华
网站建设 2026/2/8 8:41:46

Vim插件管理革命:VAM让你的编辑器告别插件混乱

Vim插件管理革命&#xff1a;VAM让你的编辑器告别插件混乱 【免费下载链接】vim-addon-manager manage and install vim plugins (including their dependencies) in a sane way. If you have any trouble contact me. Usually I reply within 24 hours 项目地址: https://gi…

作者头像 李华
网站建设 2026/2/5 13:29:36

AI攻防实战:利用AI攻击链框架剖析AI应用安全

利用AI攻击链框架对AI应用进行攻击建模 AI应用引入了传统安全模型无法完全捕捉的新攻击面&#xff0c;尤其是随着这些智能系统自主性的增强。不断演变的攻击面的指导原则很明确&#xff1a;假设存在提示词注入。但将其转化为有效的防御措施通常并不简单。 网络攻击链安全框架…

作者头像 李华