Vue的事件總線

事件總線是什么?

EventBus 又稱為事件總線。在Vue中可以使用 EventBus 來作為溝通橋梁的概念,就像是所有組件共用相同的事件中心,可以向該中心注冊發(fā)送事件或接收事件,所以組件都可以上下平行地通知其他組件,但也就是太方便所以若使用不慎,就會造成難以維護的“災(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頁面 在按鈕上面綁定了點擊事件,發(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 。事實上,我們還可以通過別的方式,讓事情變得簡單一些。那就是創(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 如何實例化,又是如何通過 $emit 發(fā)送頻道信號,又是如何通過 $on 來接收頻道信號。最后簡單介紹了如何創(chuàng)建全局的 EventBus 。從實例中我們可以了解到, EventBus 可以較好的實現(xiàn)兄弟組件之間的數(shù)據(jù)通訊。



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

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容