比起 Vue 实例上的 EventBus,mitt.js 好在哪里呢?
首先它足够小,仅有200bytes。
其次支持全部事件的监听和批量移除。
它还不依赖 Vue 实例,可以跨框架使用,React 或者 Vue,甚至 jQuery 项目都能使用同一套库。
项目中安装mitt
npm install --save mitt
使用方式一:在原型中声明
一、在 main.ts\color{#ef2d26}{main.ts}main.ts 中注册挂载到全局
import { createApp } from 'vue'
import App from './App.vue'
import mitt from 'mitt'
import router from "./router";
const app = createApp(App)
// vue3挂载到全局
app.config.globalProperties.$mitt = mitt();
app.use(router).mount('#app')二、在home.vue组件中使用 emit\color{#ef2d26}{emit}emit 发送信息
立即学习“前端免费学习笔记(深入)”;
这里是home组件
二、在about.vue组件中使用 on\color{#ef2d26}{on}on 接收信息
使用方式二:在组件中引用
一、新建 bus.ts\color{#ef2d26}{bus.ts}bus.ts 文件
import mitt from "mitt"; const emiter = mitt(); export default emiter;
二、在home.vue组件中引入并使用 emit\color{#ef2d26}{emit}emit 发送信息
这里是home组件
二、在about.vue组件中引入并使用 on\color{#ef2d26}{on}on 接收信息
这里是about组件
接收到的数据:{{ amount }}










