vue3中使用mitt全局事件总线

一. 事件总线的基本原理

事件总线本质上是一个全局的事件管理器,提供以下功能:

  • 事件发布(emit) :发送消息通知其他订阅者某事件已发生。
  • 事件订阅(on) :监听指定事件,当事件触发时执行回调。
  • 事件移除(off) :取消事件监听,避免内存泄漏。

优点是松耦合、易扩展。

二. 如何在 Vue3 微前端项目中创建事件总线

Vue3 本身不再内置事件总线,但可以利用第三方库或自行实现。

1. 使用 mitt 创建事件总线

mitt 是一个体积轻巧、API 简单的事件发射器,适合微前端场景。

安装

js 复制代码
npm install mitt

创建事件总线实例

js 复制代码
// eventBus.ts
import mitt from 'mitt'

type Events = {
  'user-login': { id: number; name: string }
  'theme-change': string
  // 可根据需求定义更多事件类型
}

const eventBus = mitt<Events>()

export default eventBus

通过 TypeScript 类型定义,事件和数据结构更安全。

2. 如何使用事件总线通信

组件1发布事件通知

js 复制代码
import eventBus from './eventBus'

function loginSuccess(user: { id: number; name: string }) {
  eventBus.emit('user-login', user)
}

组件2监听事件

js 复制代码
import eventBus from './eventBus'
import { onMounted, onUnmounted } from 'vue'

const handler = (userInfo) => {
    console.log('收到用户登录事件:', userInfo)
} 
onMounted(() => {
    eventBus.on('user-login', handler)
})
onUnmounted(() => {
    eventBus.off('user-login', handler)
})

通过 eventBus.emit 发布事件,通过 eventBus.on 监听,实现跨组件通信。由于事件总线的监听者可能长时间驻留,务必在组件卸载时取消事件监听。

相关推荐
Laurence1 分钟前
Qt 前后端通信(QWebChannel Js / C++ 互操作):原理、示例、步骤解说
前端·javascript·c++·后端·交互·qwebchannel·互操作
Pu_Nine_95 分钟前
JavaScript 字符串与数组核心方法详解
前端·javascript·ecmascript
这是个栗子12 分钟前
前端开发中的常用工具函数(六)
javascript·every
kyriewen42 分钟前
异步编程:从“回调地狱”到“async/await”的救赎之路
前端·javascript·面试
前端Hardy1 小时前
别再手动写 loading 了!封装一个自动防重提交的 Hook
前端·javascript·vue.js
前端Hardy1 小时前
前端如何实现“无感刷新”Token?90% 的人都做错了
前端·javascript·vue.js
SuperEugene1 小时前
Vue Router 实战规范:path/name/meta 配置 + 动态 / 嵌套路由,统一团队标准|状态管理与路由规范篇
开发语言·前端·javascript·vue.js·前端框架
张一凡931 小时前
easy-model -- "小而美"的React状态管理方案
前端·javascript·react.js
前端Hardy1 小时前
纯 HTML/CSS/JS 实现的高颜值登录页,还会眨眼睛!少女心爆棚!
前端·javascript·vue.js
includei1 小时前
【JavaScript】华为机试_HJ20_密码验证合格程序
开发语言·javascript·华为