手把手学习Vue3.0:Vue3.0正确使用Bus总线mitt实现组件间通信和传参

4,950 阅读2分钟

背景

在使用Vue做后台管理系统的过程中,需要实现组件间的参数传递。Bus方式非常简洁方便,却遇到一个奇怪的现象,我单击菜单区域,需要在header中展示操作导航,内容区域做展示。结果header区域没有反应。下面我分别介绍Vue3.0如何集成Bus,同时复盘一下问题的整个过程。

Vue3.0集成Bus 

  • Vue到3.0之后的Bus的方式变成了使用mitt。2.0是通过创建一个空的Vue来作为总线。
  • 使用emit来注册,emitt("type","event");,可以先这样理解:第一个参数可以理解成事件名称,第二个参数通常是参数。
  • 使用on来监听,on("type",“handler”=>{这里是具体操作逻辑});第一个参数同上的第一个参数要对应上,才说明一个事件。
  • emitt和on是成对出现,一个发起,一个接收。
  • 2.0之前是$emitt,$on,3.0去掉了$,后面给出例子
  • 接收方可以是多个组件,只要第一个参数匹配都可以获取到想要的数据,这样确实很方便,也是Vue的一个优势。

方式一:全局引入

  • 首先安装mitt
cnpm install --save mitt
  • 在main.js中引入
import { createApp } from "vue";
import App from "./App.vue";
import router from "./router";
import store from "./store";
//这里引入
import mitt from "mitt";

const app = createApp(App);
app
  .use(store)
  .use(router)
  .mount("#app");
//这里初始化
app.config.globalProperties.$bus = mitt();
  • 页面中使用 ,由于是全局的,所以在使用页面中不需要再引入,直接使用。代码如下:
  • 发起方:我这个例子是在选中方法中发起。

  • 接收方:记住一定要写在mounted,这里一定要格外注意,千万不要写在method中,如果你用WebStorm是不会报错误的,这个bug非常不好排查,我是深受其害,费了很大劲才找到错误。

方式二:按需引入,即那个组件需要就在哪里引入,我个人比较推荐这种方式。

  • 在src下新建package,命名为bus,新建bus.js

  • bus.js中引入mitt,同时对外声明bus,在使用页面直接引入bus即可。
import mitt from "mitt";

const bus = mitt();

export default bus;
  • 发起方:使用上的区别如图中代码

  • 接收方:

总结

  • Vue3.0对于Bus的正确引入和引用的两种方式都说明白了
  •  也给大家分享了我遇到的一个问题,还是书写的问题
  • 对于生命周期大家也要格外留心
  • 我没有遇到多执行的问题,后面再说
  • 如果对你有帮助,一键三联。