当前位置: 首页 > article >正文

Vue中的自定义事件

一、前言

在 Vue 的组件化开发中,组件之间的数据通信是构建复杂应用的关键。而其中最常见、最推荐的方式之一就是通过 自定义事件(Custom Events) 来实现父子组件之间的交互。

本文将带你深入了解:

  • Vue 中事件的基本概念
  • 如何在子组件中触发自定义事件
  • 如何在父组件中监听并处理这些事件
  • 自定义事件的命名规范与最佳实践
  • Vue 2 与 Vue 3 在事件处理上的差异对比

掌握 Vue 自定义事件的使用方法,是构建可维护、高内聚组件系统的基础。

二、什么是 Vue 的自定义事件?

在 Vue 中,自定义事件(Custom Events) 是子组件向父组件传递信息的一种机制。它允许我们在子组件中定义一个事件名称,并在某个操作发生时触发这个事件,然后由父组件监听该事件并做出响应。

📌 通俗理解:

  • 子组件说:“我做了某件事!”
  • 父组件听到了,并回应:“我知道了,我会做相应的处理。”

三、如何定义和触发自定义事件?

✅ 步骤 1:在子组件中定义并触发事件

<!-- ChildComponent.vue -->
<template><button @click="notifyParent">点击通知父组件</button>
</template><script>
export default {name: 'ChildComponent',methods: {notifyParent() {// 触发名为 "child-event" 的自定义事件this.$emit('child-event', { message: '来自子组件的消息' });}}
}
</script>

✅ 步骤 2:在父组件中监听并处理事件

<!-- ParentComponent.vue -->
<template><div><h2>父组件</h2><ChildComponent @child-event="handleChildEvent" /><p>接收到的消息:{{ receivedMessage }}</p></div>
</template><script>
import ChildComponent from './ChildComponent.vue'export default {components: { ChildComponent },data() {return {receivedMessage: ''}},methods: {handleChildEvent(payload) {console.log('父组件接收到事件', payload);this.receivedMessage = payload.message;}}
}
</script>

在这个例子中,当用户点击子组件按钮时,会触发 child-event 事件,并携带数据传给父组件,父组件通过 @child-event 监听并更新页面状态。

四、Vue 3 Composition API 中的事件写法(<script setup>

在 Vue 3 的 <script setup> 语法糖中,我们可以使用 defineEmits() 来声明和触发事件。

<!-- ChildComponent.vue -->
<template><button @click="notifyParent">点击通知父组件</button>
</template><script setup>
const emit = defineEmits(['child-event'])function notifyParent() {emit('child-event', { message: '来自子组件的消息' })
}
</script>

父组件写法不变,仍通过 @child-event 进行监听。

五、自定义事件的命名建议

类型建议
事件名推荐使用小写 + 短横线命名(kebab-case),如 update-dataform-submit
参数传递可以传递任意类型的数据(字符串、数字、对象等)
多个参数可以传多个参数,但建议封装为对象更易维护
异步处理可结合 Promise 或 async/await 实现异步逻辑

六、常见的自定义事件应用场景

场景示例
表单提交子组件点击提交后触发 submit 事件,父组件处理请求
数据变更通知子组件修改了某些值后,通知父组件刷新视图
按钮点击回调子组件按钮点击后触发特定业务逻辑
组件销毁前通知使用 beforeUnmount 钩子触发清理事件
分页器翻页子组件分页变化后通知父组件加载新数据

七、Vue 2 与 Vue 3 事件机制的区别

对比项Vue 2Vue 3
事件定义方式通过 $emit() 直接触发支持 $emit(),也支持 defineEmits()
事件监听方式使用 v-on 或 .native 监听原生事件使用 v-on,新增 defineProps 和 defineEmits 更加语义化
支持 modelValue / update:modelValue❌ 不支持✅ 支持 v-model 的双向绑定
支持组合式 API❌ 不支持✅ 完全支持

📌 迁移建议: 如果你正在从 Vue 2 升级到 Vue 3,请注意使用 defineEmits() 替代 this.$emit(),并保持良好的事件命名习惯。

八、自定义事件的最佳实践

实践建议说明
使用语义化的事件名如 submitchangeupdate,增强可读性
避免滥用事件尽量避免过多嵌套或复杂事件链,推荐使用 Vuex/Pinia 管理全局状态
保持事件单一职责一个事件只代表一个行为
合理传递数据控制数据大小,避免传递大量冗余数据
结合 v-model 使用实现父子组件双向绑定
使用 TypeScript 类型定义提升类型安全性与开发体验

九、结语

感谢您的阅读!如果你有任何疑问或想要分享的经验,请在评论区留言交流!

相关文章:

Vue中的自定义事件

一、前言 在 Vue 的组件化开发中&#xff0c;组件之间的数据通信是构建复杂应用的关键。而其中最常见、最推荐的方式之一就是通过 自定义事件&#xff08;Custom Events&#xff09; 来实现父子组件之间的交互。 本文将带你深入了解&#xff1a; Vue 中事件的基本概念如何在…...

2025年大模型平台落地实践研究报告|附75页PDF文件下载

本报告旨在为各行业企业在建设落地大模型平台的过程中&#xff0c;提供有效的参考和指引&#xff0c;助力大模型更高效更有价值地规模化落地。本报告系统性梳理了大模型平台的发展背景、历程和现状&#xff0c;结合大模型平台的特点提出了具体的落地策略与路径&#xff0c;同时…...

PPTAGENT:让PPT生成更智能

想要掌握如何将大模型的力量发挥到极致吗&#xff1f;叶梓老师带您深入了解 Llama Factory —— 一款革命性的大模型微调工具。 1小时实战课程&#xff0c;您将学习到如何轻松上手并有效利用 Llama Factory 来微调您的模型&#xff0c;以发挥其最大潜力。 CSDN教学平台录播地址…...

Kotlin 中 companion object 扩展函数和普通函数区别

在 Kotlin 中&#xff0c;companion object 的扩展函数与普通函数&#xff08;包括普通成员函数和普通扩展函数&#xff09;有显著区别。以下是它们的核心差异和适用场景&#xff1a; 1. 定义位置与归属 特性companion object 扩展函数普通函数定义位置在类外部为伴生对象添加…...

《汇编语言》第13章 int指令

中断信息可以来自 CPU 的内部和外部&#xff0c;当 CPU 的内部有需要处理的事情发生的时候&#xff0c;将产生需要马上处理的中断信息&#xff0c;引发中断过程。在第12章中&#xff0c;我们讲解了中断过程和两种内中断的处理。 这一章中&#xff0c;我们讲解另一种重要的内中断…...

Redis实战-基于redis和lua脚本实现分布式锁以及Redission源码解析【万字长文】

前言&#xff1a; 在上篇博客中&#xff0c;我们探讨了单机模式下如何通过悲观锁&#xff08;synchronized&#xff09;实现"一人一单"功能。然而&#xff0c;在分布式系统或集群环境下&#xff0c;单纯依赖JVM级别的锁机制会出现线程并发安全问题&#xff0c;因为这…...

Ubuntu崩溃修复方案

当Ubuntu系统崩溃时,可依据崩溃类型(启动失败、运行时崩溃、完全无响应)选择以下修复方案。以下方法综合了官方推荐和社区实践,按操作风险由低到高排序: 一、恢复模式(Recovery Mode) 适用场景​​:系统启动卡顿、登录后黑屏、软件包损坏等。 ​​操作步骤​​: ​…...

计算机网络 : 应用层自定义协议与序列化

计算机网络 &#xff1a; 应用层自定义协议与序列化 目录 计算机网络 &#xff1a; 应用层自定义协议与序列化引言1. 应用层协议1.1 再谈协议1.2 网络版计算器1.3 序列化与反序列化 2. 重新理解全双工3. socket和协议的封装4. 关于流失数据的处理5. Jsoncpp5.1 特性5.2 安装5.3…...

Python Day42 学习(日志Day9复习)

补充&#xff1a;关于“箱线图”的阅读 以下图为例 浙大疏锦行 箱线图的基本组成 箱体&#xff08;Box&#xff09;&#xff1a;中间的矩形&#xff0c;表示数据的中间50%&#xff08;从下四分位数Q1到上四分位数Q3&#xff09;。中位线&#xff08;Median&#xff09;&#…...

CMake在VS中使用远程调试

选中CMakeLists.txt, 右键-添加调试配置-选中"C\C远程windows调试" 之后将 aunch.vs.json文件改为如下所示: CMake在VS中使用远程调试时,Launch.vs.json中远程调试设置 ,远程电脑开启VS专用的RemoteDebugger {"version": "0.2.1","defaul…...

《图解技术体系》How Redis Architecture Evolves?

Redis架构的演进经历了多个关键阶段&#xff0c;从最初的内存数据库发展为支持分布式、多模型和持久化的高性能系统。以下为具体演进路径&#xff1a; 单线程模型与基础数据结构 Redis最初采用单线程架构&#xff0c;利用高效的I/O多路复用&#xff08;如epoll&#xff09;处…...

从零搭建到 App Store 上架:跨平台开发者使用 Appuploader与其他工具的实战经验

对于很多独立开发者或小型团队来说&#xff0c;开发一个 iOS 应用并不难&#xff0c;真正的挑战在于最后一步&#xff1a;将应用成功上架到 App Store。尤其是当你主要在 Windows 或 Linux 系统上开发&#xff0c;缺乏苹果设备和 macOS 环境时&#xff0c;上架流程往往变得繁琐…...

Spring Cloud 2025 正式发布啦

文章目录 一、版本兼容性二、Spring Cloud Gateway 重大更新1、新增功能1.1 Function & Stream 处理器集成1.2 Bucket4j 限流器支持 2、重要弃用2.1. WebClientRouting 基础设施2.2. 模块和启动器重命名 3、破坏性变更3.1 X-Forwarded-* 头部默认禁用3.2 配置受信任代理:3.…...

一文速通Python并行计算:12 Python多进程编程-进程池Pool

一文速通 Python 并行计算&#xff1a;12 Python 多进程编程-进程池 Pool 摘要&#xff1a; 在Python多进程编程中&#xff0c;Pool类用于创建进程池&#xff0c;可并行执行多个任务。通过map、apply等方法&#xff0c;将函数和参数分发到子进程&#xff0c;提高CPU利用率&…...

相机Camera日志分析之二十五:高通相机Camx 基于预览1帧的process_capture_request四级日志分析详解

【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:相机Camera日志分析之二十四:高通相机Camx 基于预览1帧的process_capture_request三级日志分析详解 ok 这一篇我们开始讲: 相机Camera日志分析之二十五:高通相机Camx 基于预览1帧的process_capture_…...

React从基础入门到高级实战:React 实战项目 - 项目一:在线待办事项应用

React 实战项目&#xff1a;在线待办事项应用 欢迎来到本 React 开发教程专栏的第 26 篇&#xff01;在之前的 25 篇文章中&#xff0c;我们从 React 的基础概念逐步深入到高级技巧&#xff0c;涵盖了组件、状态、路由和性能优化等核心知识。这一次&#xff0c;我们将通过一个…...

云部署实战:基于AWS EC2/Aliyun ECS与GitHub Actions的CI/CD全流程指南

在当今快速迭代的软件开发环境中&#xff0c;云部署与持续集成/持续交付(CI/CD)已成为现代开发团队的标配。本文将详细介绍如何利用AWS EC2或阿里云ECS结合GitHub Actions构建高效的CI/CD流水线&#xff0c;从零开始实现自动化部署的全过程。 最近挖到一个宝藏级人工智能学习网…...

golang 如何定义一种能够与自身类型值进行比较的Interface

定义一种具有比较能力的类型是一种常见需求&#xff0c;比如对一组相同类型的值进行排序&#xff0c;就需要进行两两比较&#xff0c;那么在Go语言中有没有办法定义一种具有比较能力的Interface&#xff0c;实现该接口的类型都具备比较能力呢&#xff0c;最常见最容易的办法是定…...

Web前端之原生表格动态复杂合并行、Vue

MENU 效果公共数据纯原生StyleJavaScript vue原生table 效果 原生的JavaScript原生table null 公共数据 const list [{id: "a1",title: "第一列",list: [{id: "a11",parentId: "a1",title: "第二列",list: [{ id: "…...

『uniapp』把接口的内容下载为txt本地保存 / 读取本地保存的txt文件内容(详细图文注释)

目录 预览效果思路分析downloadTxt 方法readTxt 方法 完整代码总结 欢迎关注 『uniapp』 专栏&#xff0c;持续更新中 欢迎关注 『uniapp』 专栏&#xff0c;持续更新中 预览效果 思路分析 downloadTxt 方法 该方法主要完成两个任务&#xff1a; 下载 txt 文件&#xff1a;通…...

C/C++ 面试复习笔记(2)

C语言如何实现快速排序算法&#xff1f; 答案&#xff1a;快排是一种分治算法&#xff0c;选择一个基准元素&#xff0c;将数据划分成两部分&#xff0c;然后递归排序 补充&#xff1a; void quick_sort(int arr[], int start, int end) {//判断是否需要排序if (start > …...

宝马集团推进数字化转型:强化生产物流与财务流程,全面引入SAP现代架构

2025年6月&#xff0c;宝马集团宣布在生产物流与财务流程领域取得重大数字化成果。这些进展标志着集团全球范围内采用基于云的新型SAP架构进入关键阶段&#xff0c;旨在提升运营效率、透明度和AI能力&#xff0c;为未来工业发展奠定技术基础。 一、生产物流全球数字化部署 宝…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 时间事件处理部分)

揭秘高效存储模型与数据结构底层实现 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 时间事件&#xff1a;serverCron函数更新服务器时间缓存更新LRU时钟-lruclock更新服务器每秒执行命令次…...

【DAY40】训练和测试的规范写法

内容来自浙大疏锦行python打卡训练营 浙大疏锦行 知识点&#xff1a; 彩色和灰度图片测试和训练的规范写法&#xff1a;封装在函数中展平操作&#xff1a;除第一个维度batchsize外全部展平dropout操作&#xff1a;训练阶段随机丢弃神经元&#xff0c;测试阶段eval模式关闭drop…...

C语言 标准I/O函数全面指南

C标准I/O函数全面指南 本指南详细介绍了C语言中用于文件操作的标准输入/输出函数&#xff0c;包括单字符I/O、字符串I/O、格式化I/O、块I/O以及文件光标操作。每个部分包含函数定义、使用说明和实用示例&#xff0c;适合学习、复习以及博客发布。内容采用清晰的Markdown格式&a…...

el-select 实现分页加载,切换也数滚回到顶部,自定义高度

el-select 实现分页加载&#xff0c;切换也数滚回到顶部&#xff0c;自定义高度 1.html <el-form-item label"俱乐部&#xff1a;" prop"club_id" label-width"120px"><el-select :disabled"Boolean(match_id)" style"w…...

Langchaine4j 流式输出 (6)

Langchaine4j 流式输出 大模型的流式输出是指大模型在生成文本或其他类型的数据时&#xff0c;不是等到整个生成过程完成后再一次性 返回所有内容&#xff0c;而是生成一部分就立即发送一部分给用户或下游系统&#xff0c;以逐步、逐块的方式返回结果。 这样&#xff0c;用户…...

Jenkins:自动化流水线的基石,开启 DevOps 新时代

从持续集成到持续交付的全流程自动化工具 一、什么是 Jenkins&#xff1f; Jenkins 是一款开源的 自动化服务器&#xff0c;专注于持续集成&#xff08;CI&#xff09;和持续交付&#xff08;CD&#xff09;。它通过插件化的架构支持几乎所有的开发、运维和测试工具&#xff…...

学习经验分享【40】目标检测热力图制作

目标检测热力图在学术论文&#xff08;尤其是计算机视觉、深度学习领域&#xff09;中是重要的可视化分析工具和论证辅助手段&#xff0c;可以给论文加分不少。主要作用一是增强论文的可解释性与说服力&#xff1a;论文中常需解释模型 “如何” 或 “为何” 检测到目标&#xf…...

C#里与嵌入式系统W5500网络通讯(3)

有与W5500通讯时,需要使用下面的寄存器: PHYCFGR (W5500 PHY Configuration Register) [R/W] [0x002E] [0b10111XXX] PHYCFGR configures PHY operation mode and resets PHY. In addition, PHYCFGR indicates the status of PHY such as duplex, Speed, Link. 这张表格详细…...