-
一种组件间通信的方式,适用于任意组件间通信。
-
安装全局事件总线:
new Vue({ .... beforeCreate(){ Vue.prototype.$bus = this **// 安装全局事件总线,$bus 就是当前应用的vm** }, ...... })
-
使用事件总线:
1. 接收数据:A 组件想接收数据,则在A组件中给 $bus 绑定自定义事件,事件的回调留在 A 组件自身methods(){ demo(data){.....} } ...... mounted(){ this.$bus.$on('xxx',this.demo) }
2. 提供数据:
this.$bus.$emit('xxx',数据)
4. 最好在 beforeDeatrot 钩子中,用 $off 去解绑当前组件所用到的事件