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