news 2026/6/9 16:07:07

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/6/4 20:08:50

YOLO26如何更新?官方代码库同步升级方法

YOLO26如何更新&#xff1f;官方代码库同步升级方法 YOLO系列模型持续演进&#xff0c;但“YOLO26”并非Ultralytics官方发布的正式版本编号。当前&#xff08;截至2024年中&#xff09;Ultralytics官方维护的最新稳定版为 YOLOv8&#xff08;主干版本号8.x&#xff09;&#…

作者头像 李华
网站建设 2026/6/8 18:23:59

推翻150年数学直觉:数学家烧坏几台笔记本,解决几何拓扑难题

来源&#xff1a;机器之心编译这是一次数学理论与计算机算力结合的胜利。设想一下&#xff0c;如果我们的天空总是被一层厚厚的不透明云层所遮蔽&#xff0c;既看不见星星&#xff0c;也无法从上方俯瞰我们的星球&#xff0c;我们还能发现地球是圆的吗&#xff1f;答案是肯定的…

作者头像 李华
网站建设 2026/6/9 18:37:14

踩坑记录:用SenseVoiceSmall做语音分析那些事

踩坑记录&#xff1a;用SenseVoiceSmall做语音分析那些事 1. 引言&#xff1a;为什么选择SenseVoiceSmall&#xff1f; 最近在做一个需要多语言支持的语音情感分析项目&#xff0c;目标是不仅能识别用户说了什么&#xff0c;还要知道“怎么说的”——语气是开心还是愤怒&…

作者头像 李华
网站建设 2026/6/9 21:32:40

Maven依赖管理与生命周期

1. 依赖管理&#xff1a;配置、引入与删除 1.1 添加依赖的三种方式 方式一&#xff1a;手动编辑pom.xml&#xff08;推荐&#xff09; 方式二&#xff1a;复制坐标 从Maven Repository复制依赖坐标&#xff0c;粘贴到pom.xml 1.2 删除依赖的两种方式 方式一&#xff1a;手动…

作者头像 李华
网站建设 2026/5/23 5:16:47

康复护理智能穿戴设备研发:AI 人工智能的技术支撑

康复护理智能穿戴设备研发&#xff1a;AI 人工智能的技术支撑关键词&#xff1a;康复护理、智能穿戴设备、AI算法、传感器数据、医疗健康科技摘要&#xff1a;本文从老龄化社会对康复护理的迫切需求出发&#xff0c;深入解析AI如何为康复护理智能穿戴设备提供技术支撑。通过拆解…

作者头像 李华
网站建设 2026/6/10 9:24:22

导师严选2026自考AI论文平台TOP8:8款测评哪款最实用

导师严选2026自考AI论文平台TOP8&#xff1a;8款测评哪款最实用 2026自考AI论文平台测评&#xff1a;如何选出真正实用的写作助手 随着人工智能技术在学术领域的广泛应用&#xff0c;越来越多的自考生开始依赖AI写作工具来提升论文写作效率。然而&#xff0c;面对市场上五花八门…

作者头像 李华