Vue的事件總線

事件總線是什么?

EventBus 又稱為事件總線。在Vue中可以使用 EventBus 來作為溝通橋梁的概念泛领,就像是所有組件共用相同的事件中心拐揭,可以向該中心注冊發(fā)送事件或接收事件颓芭,所以組件都可以上下平行地通知其他組件殖熟,但也就是太方便所以若使用不慎,就會造成難以維護(hù)的“災(zāi)難”叫胁,因此才需要更完善的Vuex作為狀態(tài)管理中心凰慈,將通知的概念上升到共享狀態(tài)層次。


為什么引入事件總線?

vue組件非常常見的有父子組件通信驼鹅,兄弟組件通信微谓。而父子組件通信就很簡單森篷,父組件會通過 props 向下傳數(shù)據(jù)給子組件,當(dāng)子組件有事情要告訴父組件時會通過 $emit 事件告訴父組件堰酿。今天就來說說如果兩個頁面沒有任何引入和被引入關(guān)系疾宏,該如何通信了?

如果咱們的應(yīng)用程序不需要類似Vuex這樣的庫來處理組件之間的數(shù)據(jù)通信触创,就可以考慮Vue中的 事件總線 坎藐,即?EventBus來通信。

事件總線的用法

1.首先需要創(chuàng)建事件總線并將其導(dǎo)出哼绑,以便其它模塊可以使用或者監(jiān)聽它岩馍。我們可以通過兩種方式來處理。先來看第一種抖韩,新創(chuàng)建一個 .js 文件蛀恩,比如 event-bus.js 。

//event-bus.js

import Vuefrom 'vue'

export const EventBus =new Vue()

2.我們創(chuàng)建出來后 就需要用來收發(fā)事件茂浮,發(fā)送事件

假設(shè)你有兩個Vue頁面需要通信: A 和 B 双谆,A頁面 在按鈕上面綁定了點(diǎn)擊事件,發(fā)送一則消息席揽,想=通知 B頁面顽馋。如下

<!-- A.vue -->

<template>

? ? <button @click="sendMsg()">-</button>

</template>

<script>

import { EventBus } from "../event-bus.js";

export default {

? methods: {

? ? sendMsg() {

? ? ? EventBus.$emit("aMsg", '來自A頁面的消息');

? ? }

? }

};

</script>

3.接下來,我們需要在 B頁面 中接收這則消息幌羞。接收事件

<!-- B.vue -->

? ? <template>

? ? ? <p>{{msg}}</p>

? ? </template>


? ? <script>

? ? import {

? ? ? EventBus

? ? } from "../event-bus.js";

? ? export default {

? ? ? data(){

? ? ? ? return {

? ? ? ? ? msg: ''

? ? ? ? }

? ? ? },

? ? ? mounted() {

? ? ? ? EventBus.$on("aMsg", (msg) => {

? ? ? ? ? // A發(fā)送來的消息

? ? ? ? ? this.msg = msg;

? ? ? ? });

? ? ? }

? ? };

? ? </script>

//用完之后得移除事件的監(jiān)聽

destroyed() {

? ?EventBus.$off('aMsg', {})

}

你也可以使用 EventBus.off(′aMsg′)來移除應(yīng)用內(nèi)所有對此某個事件的監(jiān)聽寸谜。或者直接調(diào)用EventBus.off('aMsg') 來移除應(yīng)用內(nèi)所有對此某個事件的監(jiān)聽属桦⌒艹眨或者直接調(diào)用 EventBus.off(′aMsg′)來移除應(yīng)用內(nèi)所有對此某個事件的監(jiān)聽∧舯觯或者直接調(diào)用EventBus.off() 來移除所有事件頻道果善,不需要添加任何參數(shù) 。

上面就是 EventBus 的使用方法系谐,是不是很簡單岭埠。上面的示例中我們也看到了,每次使用 EventBus 時都需要在各組件中引入 event-bus.js 蔚鸥。事實(shí)上,我們還可以通過別的方式许赃,讓事情變得簡單一些止喷。那就是創(chuàng)建一個全局的 EventBus 。接下來的示例向大家演示如何在Vue項目中創(chuàng)建一個全局的 EventBus 混聊。


全局EventBus

它的工作原理是發(fā)布/訂閱方法弹谁,通常稱為 Pub/Sub 。

創(chuàng)建全局EventBus

// main.js 全局的事件總線

Vue.prototype.EventBus =new Vue();

在這個特定的總線中使用兩個方法 $on 和 $emit 。一個用于創(chuàng)建發(fā)出的事件预愤,它就是 $emit 沟于;另一個用于訂閱 $on :

在A.vue中使用 發(fā)送事件:

this.EventBus.$emit("abudaren", {num:4});

在B.vue中使用 監(jiān)聽事件:

mounted() {

this.EventBus.$on("abudaren", ({ num }) => {

this.$nextTick(() => {

console.log("接收到的num為:",num)

});

});

},

同時也可以使用this.bus.bus.bus.off(‘sendMsg’)來移除事件監(jiān)聽。

總結(jié)

主要涉及了 EventBus 如何實(shí)例化植康,又是如何通過 $emit 發(fā)送頻道信號旷太,又是如何通過 $on 來接收頻道信號。最后簡單介紹了如何創(chuàng)建全局的 EventBus 销睁。從實(shí)例中我們可以了解到供璧, EventBus 可以較好的實(shí)現(xiàn)兄弟組件之間的數(shù)據(jù)通訊。



參考文獻(xiàn):Vue事件總線(EventBus)使用詳細(xì)介紹_infotw的博客-CSDN博客_vue eventbus

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末冻记,一起剝皮案震驚了整個濱河市睡毒,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌冗栗,老刑警劉巖演顾,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異隅居,居然都是意外死亡钠至,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進(jìn)店門军浆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來棕洋,“玉大人,你說我怎么就攤上這事乒融£蹋” “怎么了?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵赞季,是天一觀的道長愧捕。 經(jīng)常有香客問我,道長申钩,這世上最難降的妖魔是什么次绘? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮撒遣,結(jié)果婚禮上邮偎,老公的妹妹穿的比我還像新娘。我一直安慰自己义黎,他們只是感情好禾进,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著廉涕,像睡著了一般泻云。 火紅的嫁衣襯著肌膚如雪艇拍。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天宠纯,我揣著相機(jī)與錄音卸夕,去河邊找鬼。 笑死婆瓜,一個胖子當(dāng)著我的面吹牛快集,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播勃救,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼碍讨,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了蒙秒?” 一聲冷哼從身側(cè)響起勃黍,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎晕讲,沒想到半個月后覆获,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡瓢省,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年弄息,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片勤婚。...
    茶點(diǎn)故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡摹量,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出馒胆,到底是詐尸還是另有隱情缨称,我是刑警寧澤,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布祝迂,位于F島的核電站睦尽,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏型雳。R本人自食惡果不足惜当凡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望纠俭。 院中可真熱鬧沿量,春花似錦、人聲如沸冤荆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽匙赞。三九已至佛掖,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間涌庭,已是汗流浹背芥被。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留坐榆,地道東北人拴魄。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像席镀,于是被迫代替她去往敵國和親匹中。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,792評論 2 345