1.一种组件间通信的方式,适用于任意组件间通信
2.使用步骤:
(1).安装
pubsub: npm i pubsub-js
(2).引入:
import pubsub from 'pubsub-js'
(3).接收数据:A组件想接收数据,则在A组件中订阅消息,订阅的回调留在A组件自身
//消息订阅第一种方式
mounted() {
this.pubId = pubsub.subscribe('hello',(msgName,data) => {
console.log('有人发布了hello消息,hello消息的回调执行了',msgName,data);
})
},
//消息订阅第二种方式
methods: {
demo(msgName,data){
console.log('有人发布了hello消失,hello消失的回调执行了',msgName,data);
}
},
mounted() {
this.pubId = pubsub.subscribe('hello',this.demo) 订阅消息
},
beforeDestroy(){
pubsub.unsubscribe(this.pubId)
}
(4).提供数据:
pubsub.publish('hello',this.name)
(5).最好在 beforeDestroy钩子中,用 pubsub.unsubscribe(this.pubId)取消订阅