Vue3一兄弟组件传值之mitt,超详细!

Vue2.x 使用 EventBus 事件总线进行兄弟组件通信,而在Vue3中事件总线模式已经被移除,官方建议使用外部的、实现了事件触发器接口的库,例如 mitt 或 tiny-emitter。

比起 Vue 实例上的 EventBus,mitt.js 好在哪里呢?

  1. 首先它足够小,仅有200bytes。
  2. 其次支持全部事件的监听和批量移除。
  3. 它还不依赖 Vue 实例,可以跨框架使用,React 或者 Vue,甚至 jQuery 项目都能使用同一套库。

项目中安装mitt

npm install --save mitt

使用方式一:在原型中声明

一、在 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 发送信息





二、在about.vue组件中使用 on 接收信息





使用方式二:在组件中引用

一、新建bus.ts 文件

import mitt from "mitt";

const emiter = mitt();

export default emiter;

二、在home.vue组件中引入并使用 emit 发送信息





二、在about.vue组件中引入并使用 on 接收信息





你可能感兴趣的:(javascript,前端,vue.js)