news 2026/1/25 7:53:51

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/1/22 0:14:30

Qwen2.5-0.5B边缘部署挑战:内存泄漏检测与修复教程

Qwen2.5-0.5B边缘部署挑战&#xff1a;内存泄漏检测与修复教程 1. 引言&#xff1a;为什么小模型也逃不过内存问题&#xff1f; 你可能以为&#xff0c;像 Qwen2.5-0.5B-Instruct 这样仅 0.5B 参数、权重约 1GB 的轻量级模型&#xff0c;在 CPU 边缘设备上运行应该是“稳如老…

作者头像 李华
网站建设 2026/1/22 0:14:30

BabelDOC深度解密:重新定义PDF翻译新标准

BabelDOC深度解密&#xff1a;重新定义PDF翻译新标准 【免费下载链接】BabelDOC Yet Another Document Translator 项目地址: https://gitcode.com/GitHub_Trending/ba/BabelDOC 还在为阅读外文PDF文档而头疼吗&#xff1f;BabelDOC作为一款革命性的文档翻译工具&#x…

作者头像 李华
网站建设 2026/1/22 0:14:29

BabelDOC完全指南:三步掌握智能PDF翻译技术

BabelDOC完全指南&#xff1a;三步掌握智能PDF翻译技术 【免费下载链接】BabelDOC Yet Another Document Translator 项目地址: https://gitcode.com/GitHub_Trending/ba/BabelDOC 还在为外文PDF文档的阅读障碍而烦恼吗&#xff1f;BabelDOC作为一款专业的智能文档翻译工…

作者头像 李华
网站建设 2026/1/23 2:31:48

动手实操:YOLOv10官方镜像训练全过程分享

动手实操&#xff1a;YOLOv10官方镜像训练全过程分享 你有没有经历过这样的场景&#xff1f;为了调一个学习率&#xff0c;反复跑好几轮训练&#xff1b;明明数据没问题&#xff0c;模型却总是收敛不理想&#xff1b;好不容易训完&#xff0c;部署时又卡在ONNX导出失败……这些…

作者头像 李华
网站建设 2026/1/22 0:13:20

轻量级大模型怎么用?gpt-oss-20b-WEBUI详细体验分享

轻量级大模型怎么用&#xff1f;gpt-oss-20b-WEBUI详细体验分享 最近试用了CSDN星图镜像广场上新上架的 gpt-oss-20b-WEBUI 镜像&#xff0c;整个过程比预想中更顺滑——没有编译报错、不用手动装依赖、不折腾CUDA版本&#xff0c;点几下就跑起来了。它不像动辄要80G显存的70B…

作者头像 李华
网站建设 2026/1/24 21:24:28

HY-MT1.5-7B大模型核心优势解析|附多语言翻译实践案例

HY-MT1.5-7B大模型核心优势解析&#xff5c;附多语言翻译实践案例 在全球化协作日益频繁的今天&#xff0c;高质量、低延迟、安全可控的翻译系统已成为科研、企业出海、内容本地化等场景的核心基础设施。然而&#xff0c;大多数翻译方案仍面临两难&#xff1a;要么依赖云端API…

作者头像 李华