Vue中事件總線(eventBus)的深入詳解及使用
1. 簡(jiǎn)介
Vue 組件中常見的有:父子組件通信、兄弟組件通信。而父子組件通信就很簡(jiǎn)單,父組件會(huì)通過(guò) props 向下傳數(shù)據(jù)給子組件,當(dāng)子組件有事情要告訴父組件時(shí)會(huì)通過(guò) $emit 事件告訴父組件。
今天就來(lái)說(shuō)說(shuō),如果兩個(gè)頁(yè)面沒(méi)有任何引入和被引入關(guān)系,該如何通信呢?
如果應(yīng)用程序不需要類似 Vuex 這樣的庫(kù)來(lái)處理組件之間的數(shù)據(jù)通信,就可以考慮 Vue 中的事件總線 ,即 eventBus 來(lái)通信。
eventBus 又稱為事件總線。在 Vue 中可使用 eventBus 來(lái)作為溝通橋梁的概念,就像是所有組件共用相同的事件中心,可向該中心注冊(cè)發(fā)送事件或接收事件,所以組件都可以上下平行地通知其他組件。但也就是太方便所以若使用不慎,就會(huì)造成難以維護(hù)的“災(zāi)難”,因此才需要更完善的 Vuex 作為狀態(tài)管理中心,將通知的概念上升到共享狀態(tài)層次。
2. 使用
可以聲明一個(gè)全局變量來(lái)使用事件中心,但如果在使用 webpack 之類的模塊系統(tǒng),這顯然不合適。
每次使用都手動(dòng) import 進(jìn)來(lái)也很不方便,所以本文使用 vue-bus 插件。
安裝及引入
npm install vue-bus --save
如果在一個(gè)模塊化工程中使用它,必須要通過(guò) Vue.use() 明確地安裝 vue-bus:
// main.js import Vue from 'vue'; import VueBus from 'vue-bus'; Vue.use(VueBus);
在組件中使用
假設(shè)有兩個(gè)Vue組件需要通信 ,在 A 組件的按鈕上面綁定了點(diǎn)擊事件發(fā)送一則消息,想通知 B 組件。
// A 組件
<template>
<div class="wrap">
<button @click="sendMsg">觸發(fā)</button>
</div>
</template>
<script>
export default {
data(){
return {
Amsg:'我是來(lái)自A組件的信息',
}
},
methods:{
sendMsg(){
this.$bus.emit('changeMsg', this.Amsg );
this.$bus.emit('doOnce','我只會(huì)觸發(fā)一次');
}
},
}
</script>
// B 組件
<template>
<div>
<h3>{{Bmsg}}</h3>
</div>
</template>
<script>
export default {
data(){
return {
Bmsg:'我是B組件',
}
},
methods:{
getMsg(msg){
this.Bmsg = msg;
console.log(msg);
}
},
created(){
/*
* 接收事件
* 這種寫法也體現(xiàn)了:A 組件調(diào)用 B 組件中的方法。如果只是傳遞數(shù)據(jù),可參考如下簡(jiǎn)化寫法:
* this.$bus.on('changeMsg', (msg) => { this.Bmsg = msg });
*/
this.$bus.on('changeMsg', this.getMsg);
// 此偵聽器只會(huì)觸發(fā)一次
this.$bus.once('doOnce', (txt) => { console.log(txt) });
},
// 組件銷毀時(shí),移除EventBus事件監(jiān)聽
beforeDestroy() {
this.$bus.off('changeMsg', this.addTodo);
},
}
</script>
當(dāng)我們點(diǎn)擊5次觸發(fā)按鈕時(shí),效果如下:

補(bǔ)充:移除監(jiān)聽事件
為了避免在監(jiān)聽時(shí),事件被反復(fù)觸發(fā),通常需要在頁(yè)面銷毀時(shí)移除事件監(jiān)聽。或者在開發(fā)過(guò)程中,由于熱更新,事件可能會(huì)被多次綁定監(jiān)聽,這時(shí)也需要移除事件監(jiān)聽。
//使用方式一定義時(shí)
this.$EventBus.$off('eventName');
//使用方式二定義時(shí)
EventBus.$off('eventName');
總結(jié)
eventBus 適合小項(xiàng)目、數(shù)據(jù)被更少組件使用的項(xiàng)目,對(duì)于中大型項(xiàng)目數(shù)據(jù)在很多組件之間使用的情況 eventBus 就不太適用了。eventBus 其實(shí)就是一個(gè)發(fā)布訂閱模式,利用 Vue 的自定義事件機(jī)制,在觸發(fā)的地方通過(guò) $emit 向外發(fā)布一個(gè)事件,在需要監(jiān)聽的頁(yè)面,通過(guò) $on 監(jiān)聽事件。
相關(guān)文章
Vue基礎(chǔ)之MVVM,模板語(yǔ)法和數(shù)據(jù)綁定
這篇文章主要為大家介紹了Vue之MVVM,模板語(yǔ)法和數(shù)據(jù)綁定,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2021-12-12
Vue使用el-tree 懶加載進(jìn)行增刪改查功能的實(shí)現(xiàn)
這篇文章主要介紹了Vue使用el-tree 懶加載進(jìn)行增刪改查,以懶加載的形式展示,目錄根據(jù)需求需要有新增 編輯 刪除 操作以及操作后的刷新樹結(jié)構(gòu),具體實(shí)現(xiàn)代碼跟隨小編一起看看吧2021-08-08
基礎(chǔ)的前端vite項(xiàng)目創(chuàng)建過(guò)程詳解
這篇文章主要介紹了如何使用Vite創(chuàng)建一個(gè)前端項(xiàng)目,并配置了Vue?Router、Vuex、Element?Plus、Axios和Element?Plus圖標(biāo)等第三方依賴,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-11-11
vue之Vue.use的使用場(chǎng)景及說(shuō)明
這篇文章主要介紹了vue之Vue.use的使用場(chǎng)景,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12
對(duì)vuex中g(shù)etters計(jì)算過(guò)濾操作詳解
今天小編就為大家分享一篇對(duì)vuex中g(shù)etters計(jì)算過(guò)濾操作詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11
詳解VUE Element-UI多級(jí)菜單動(dòng)態(tài)渲染的組件
這篇文章主要介紹了VUE Element-UI多級(jí)菜單動(dòng)態(tài)渲染的組件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04

