news 2026/4/19 23:17:41

Vue 3 中移除了 $on、$off 和 $once 方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue 3 中移除了 $on、$off 和 $once 方法

Vue3移除了$on、$off和$once事件API,旨在简化API并更好地支持组合式API。


主要替代方案包括:

1)使用mitt等第三方事件库;

2)基于provide/inject和响应式状态模拟事件总线;

3)使用composable共享状态;

4)采用Pinia/Vuex进行状态管理;

5)父子组件通过props/emits通信。


Vue3鼓励使用更明确的组件通信方式,如状态管理工具和组合式API,替代传统事件总线模式,使代码更可维护。


推荐优先考虑Pinia配合provide/inject或composables方案。


Vue 3 中移除了$on$off$once方法


这是 Vue 3 的一项重大变化。


为什么被移除?

Vue 3 的事件 API 重构旨在:

  1. 简化 API- 减少全局方法数量

  2. 更好地支持组合式 API- 传统的事件总线模式与组合式 API 理念不太契合

  3. 促进更明确的组件通信模式- 鼓励使用更可维护的通信方式


替代方案

1.使用第三方事件库(最接近的替代)

// 安装:npm install mitt import mitt from 'mitt'; // 创建事件总线 const emitter = mitt(); // 发送事件 emitter.emit('event-name', data); // 监听事件 emitter.on('event-name', (data) => { console.log(data); }); // 取消监听 emitter.off('event-name', handler);

2.使用 Vue 3 的 provide/inject + 响应式状态

// 事件总线模拟 import { reactive, provide, inject } from 'vue'; // 创建事件总线 const eventBusSymbol = Symbol(); export function createEventBus() { const listeners = reactive({}); return { on(event, callback) { if (!listeners[event]) listeners[event] = []; listeners[event].push(callback); }, off(event, callback) { if (listeners[event]) { const index = listeners[event].indexOf(callback); if (index > -1) listeners[event].splice(index, 1); } }, emit(event, data) { if (listeners[event]) { listeners[event].forEach(callback => callback(data)); } } }; } // 使用 export function useEventBus() { return inject(eventBusSymbol); }

3.使用 composable 替代事件总线

// counter.js - 共享状态 import { ref, readonly } from 'vue'; export function useCounter() { const count = ref(0); const increment = () => { count.value++; // 可以在这里触发其他逻辑 }; return { count: readonly(count), increment }; } // 多个组件共享同一个实例

4.使用 Vuex/Pinia 进行状态管理

// 使用 Pinia(Vue 3 推荐状态管理) import { defineStore } from 'pinia'; export const useAppStore = defineStore('app', { state: () => ({ events: [], data: null }), actions: { triggerEvent(eventName, payload) { // 处理事件逻辑 } } });

5.使用 v-model 和 emits(父子组件通信)

<!-- 子组件 --> <script setup> defineProps(['modelValue']); defineEmits(['update:modelValue']); const updateValue = (newVal) => { emit('update:modelValue', newVal); }; </script> <!-- 父组件 --> <ChildComponent v-model="value" />

迁移建议

  1. 父子组件通信→ 使用propsemits

  2. 兄弟组件通信→ 使用共同的父组件或状态管理

  3. 远房组件通信→ 使用 Pinia/Vuex 或 provide/inject

  4. 全局事件→ 使用mitt等第三方库


总结

虽然$on被移除,但 Vue 3 提供了更现代化、类型安全的替代方案。


对于大多数应用,推荐使用Pinia进行状态管理,配合provide/injectcomposables来替代传统的事件总线模式。

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

Java毕设项目推荐-基于springboot的元宇宙平台上的消费扶贫专柜管理系统【附源码+文档,调试定制服务】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/17 20:17:00

高精度中文ASR落地实践|利用Paraformer与ngram_lm优化识别

高精度中文ASR落地实践&#xff5c;利用Paraformer与ngram_lm优化识别 在语音交互日益普及的今天&#xff0c;自动语音识别&#xff08;ASR&#xff09;已成为智能客服、会议记录、字幕生成等场景的核心技术。然而&#xff0c;面对嘈杂环境、专业术语或口音差异&#xff0c;通…

作者头像 李华
网站建设 2026/4/19 18:04:53

FIND_IN_SET()方法

一、基础用法说明 FIND_IN_SET(str, strlist) 函数的作用是&#xff1a;在 strlist&#xff08;逗号分隔的字符串&#xff09;中查找 str 的位置&#xff0c;返回值是数字&#xff08;找到则返回位置&#xff0c;从1开始&#xff1b;没找到返回0&#xff09;。 结合 MyBatis 的…

作者头像 李华
网站建设 2026/4/17 19:25:41

基于ASP.NET的医院预约挂号管理系统源码文档部署文档代码讲解等

课题介绍 本课题针对传统医院挂号排队耗时久、号源管控混乱、诊疗信息不同步等痛点&#xff0c;设计并实现基于ASP.NET框架的医院预约挂号管理系统&#xff0c;构建医疗挂号全流程数字化管控平台。系统以SQL Server为数据存储核心&#xff0c;结合HTML、CSS、JavaScript及Ajax技…

作者头像 李华
网站建设 2026/4/17 8:35:01

基于微信小程序的实验室排课系统【源码+文档+调试】

&#x1f525;&#x1f525;作者&#xff1a; 米罗老师 &#x1f525;&#x1f525;个人简介&#xff1a;混迹java圈十余年&#xff0c;精通Java、小程序、数据库等。 &#x1f525;&#x1f525;各类成品Java毕设 。javaweb&#xff0c;ssm&#xff0c;springboot等项目&#…

作者头像 李华
网站建设 2026/4/16 19:30:32

springboot_ssm845股票基金分析系统的设计与实现ssm

目录 具体实现截图摘要内容 系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 具体实现截图 摘要内容 基于SpringBoot和SSM框架的股票基金分析系统旨在为投资者提供高效、便捷的数据分析与决策支持工具。系统整…

作者头像 李华