Vue组件间通信--EventBus(事件总线)/7

1|0EventBus

一种组件间通信的方式,适用于任意组件间通信。

EventBus 又称为事件总线。在Vue中可以使用 EventBus 来作为沟通桥梁的概念,就像是所有组件共用相同的事件中心,可以向该中心注册发送事件或接收事件。EventBus主要是用到发布者-订阅者的设计模式,所以代码里需要有一个地方注册事件,有另外一个或多个地方订阅事件。主要适用于小型项目

1|1注册EventBus 

在main.js文件中

new Vue({ ...... beforeCreate() { Vue.prototype.$bus = this //安装全局事件总线,$bus就是当前应用的vm }, ...... })

1|2使用事件总线

接收数据

A组件想接收数据,则在A组件中给$bus绑定自定义事件,事件的回调留在A组件自身。

methods(){ demo(data){......} } ...... mounted() { this.$bus.$on('xxxx',this.demo) }

 提供数据

this.$bus.$emit('xxxx',数据)

例: 

在main.js中挂载

在erzi这个组件中订阅

 

在xiongdi这个组件中发布

点击事件前

点击之后

总而言之,A组件只向EventBus发送了一次事件,但B组件却进行了多次监听,EventBus容器中有很多个一模一样的事件监听器这时就会出现,事件只触发一次,但监听事件中的回调函数执行了很多次

  • 解决办法:在组件离开,也就是被销毁前,将该监听事件给移除,以免下次再重复创建监听
  • 语法:this.$bus.$off(要移除监听的事件名) 
beforeDestroy(){ //移除监听事件"aMsg" this.$bus.$off("addProduct") }

 


__EOF__

本文作者长安
本文链接https://www.cnblogs.com/jingxin01/p/16413036.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   长安·念  阅读(120)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示