你不可不知的前端進階知識:Vue事件總線(EventBus)使用詳細介紹

2021-03-02 前端知道

vue組件非常常見的有父子組件通信,兄弟組件通信。而父子組件通信就很簡單,父組件會通過props向下傳數據給子組件,當子組件有事情要告訴父組件時會通過 $emit事件告訴父組件。今天就來說說如果兩個頁面沒有任何引入和被引入關係,該如何通信了?

如果咱們的應用程式不需要類似Vuex這樣的庫來處理組件之間的數據通信,就可以考慮Vue中的 事件總線 ,即 **EventBus**來通信。

EventBus 又稱為事件總線。在Vue中可以使用EventBus 來作為溝通橋梁的概念,就像是所有組件共用相同的事件中心,可以向該中心註冊發送事件或接收事件,所以組件都可以上下平行地通知其他組件,但也就是太方便所以若使用不慎,就會造成難以維護的「災難」,因此才需要更完善的Vuex作為狀態管理中心,將通知的概念上升到共享狀態層次。

首先需要創建事件總線並將其導出,以便其它模塊可以使用或者監聽它。我們可以通過兩種方式來處理。先來看第一種,新創建一個 .js 文件,比如 event-bus.js

實質上EventBus是一個不具備DOM的組件,它具有的僅僅只是它實例方法而已,因此它非常的輕便。

另外一種方式,可以直接在項目中的main.js初始化EventBus:

注意,這種方式初始化的 EventBus 是一個 全局的事件總線 。稍後再來聊一聊全局的事件總線。

現在我們已經創建了 EventBus ,接下來你需要做到的就是在你的組件中加載它,並且調用同一個方法,就如你在父子組件中互相傳遞消息一樣。

假設你有兩個Vue頁面需要通信: A 和 B ,A頁面 在按鈕上面綁定了點擊事件,發送一則消息,想=通知 B頁面。

接下來,我們需要在 B頁面 中接收這則消息。

同理我們也可以在 B頁面 向 A頁面 發送消息。這裡主要用到的兩個方法:

前面提到過,如果使用不善,EventBus 會是一種災難,到底是什麼樣的「災難」了?大家都知道vue是單頁應用,如果你在某一個頁面刷新了之後,與之相關的EventBus會被移除,這樣就導致業務走不下去。

還要就是如果業務有反覆操作的頁面,EventBus 在監聽的時候就會觸發很多次,也是一個非常大的隱患。這時候我們就需要好好處理 EventBus 在項目中的關係。通常會用到,在vue頁面銷毀時,同時移除EventBus 事件監聽。

如果想移除事件的監聽,可以像下面這樣操作:


你也可以使用EventBus.$off('aMsg')來移除應用內所有對此某個事件的監聽。或者直接調用 EventBus.$off() 來移除所有事件頻道,不需要添加任何參數 。

上面就是 EventBus 的使用方法,是不是很簡單。上面的示例中我們也看到了,每次使用 EventBus 時都需要在各組件中引入 event-bus.js 。事實上,我們還可以通過別的方式,讓事情變得簡單一些。那就是創建一個全局的 EventBus 。接下來的示例向大家演示如何在Vue項目中創建一個全局的 EventBus。

它的工作原理是發布/訂閱方法,通常稱為 Pub/Sub 。

在這個特定的總線中使用兩個方法 $on 和$emit。一個用於創建發出的事件,它就是 $emit;另一個用於訂閱 $on :

然後我們可以在某個Vue頁面使用 this.$bus.$emit("sendMsg", '我是web秀');,另一個Vue頁面使用


同時也可以使用this.$bus.$off('sendMsg')來移除事件監聽。

本文主要通過簡單的實例學習了Vue中有關於EventBus相關的知識點。主要涉及了EventBus如何實例化,又是如何通過 $emit 發送頻道信號,又是如何通過 $on 來接收頻道信號。最後簡單介紹了如何創建全局的 EventBus 。從實例中我們可以了解到,EventBus 可以較好的實現兄弟組件之間的數據通訊。

阿里P8級前端大牛袁鑫的vue-router直播課的錄播視頻免費放送啦,從中你將掌握vue-router核心內容和實現原理、獲得手寫一個router的能力。需要的小夥伴可以在公眾號對話框回復關鍵字「錄播」即可領取喲~

關注公眾號「前端知道」,分享web全棧相關的熱點知識、熱點文章,讓每個人都能由熟練工成長為專家。

*戳左下角閱讀原文可查看文章來源

相關焦點

  • Vue組件的通信--eventBus
    但是對於具有簡單體系結構的應用程式來說,使用事件在組件之間進行通信就足夠了。為此,我們可以創建一個快速的解決方案並實現EventBus,也稱作vue的中央事件總線,適用於跨級或兄弟組件。EventBus允許我們在一個組件中發出一個事件,而在另一個組件中偵聽該事件。本示例將說明如何在Vue.js應用程式中執行此操作。
  • 前端技術:開發一個vue中央事件總線插件vue-bus
    大家都知道,一個中央事件總線bus,可以作為一個簡單的組件傳遞數據,用於解決跨級和兄弟組件通信問題,那麼,這篇文字,我將使用這種思想,將bus封裝為一個Vue的插件,可以在所有的組件間任意使用,而不需要導入bus。
  • EventBus—事件總線
    Vue中就有一個消息總線的機制。當然消息總線不僅僅局限於WEB前端,Android 、IOS中的消息中心也是如此實現的。[1] 設計模式:訂閱者發布者模式。[2] API的設計: 1.首先總體上介紹一下Vue EventBus的原理:[1] Vue在實例化的時候會進行很多初始化的操作,其中包括 eventMixin 方法,該方法裡包含了上面提及的四個方法。
  • vue中的eventBus會產生內存洩漏嗎
    引入本文介紹了eventBus的實現原理,並介紹它如何在vue中使用,並舉了一個具體的例子來說明,如果使用不當,它會造成內存洩漏。fr=aladdin內容在vue使用eventBus;使用不當的問題:多次執行回調;內存洩漏;解決方案
  • 事件總線(Event Bus)知多少
    引言事件總線這個概念對你來說可能很陌生,但提到觀察者(發布-訂閱)模式,你也許就很熟悉。事件總線是對發布-訂閱模式的一種實現。它是一種集中式事件處理機制,允許不同的組件之間進行彼此通信而又不需要相互依賴,達到一種解耦的目的。我們來看看事件總線的處理流程:了解了事件總線的基本概念和處理流程,下面我們就來分析下如何去實現事件總線。
  • vue數據傳遞--我有特殊的實現技巧
    前言最近碰到了比較多的關於vue的eventBus的問題,之前定技術選型的時候也被問到了,vuex和eventBus的使用範圍。
  • thinkphp如何使用vue進行web開發
    vue可以說是近幾年最火最流行的前端js框架,而thinkphp也是國內挺流行的後端框架。看到網上很多朋友的教程都是前端開發者寫的,難免對像自己一樣的後端程式設計師是一種打擊。「怎麼就沒有從後臺出發講講如何使用前端vue框架呢?」我時常這樣想。
  • vue兄弟組件傳值的兩種方式
    本demo主要是為了演示vue項目中兄弟組件之間的傳值,這裡我演示了兩種方式:a. bus總線傳值;b.我自己一般把它當成常規的傳值(其實也就是子組件A傳父組件,父組件再傳子組 件B)下邊開始本次demo的編寫:一. bus總線傳值的使用:在項目中創建一個單獨的eventBus.js文件
  • 2020大廠前端面試之vue專題
    , 你很少會跨越層級地移動Dom元素。為了保證組件的不同的實例data不衝突,要求data必須是一個函數,這樣組件間不會相互影響20.Vue中事件綁定的原理Vue 的事件綁定分為兩種一種是原生的事件綁定,還有一種是組件的事件綁定,理解:原理:let compiler = require('vue-template-compiler');let r1 = compiler.compile
  • 高級前端進階,vue如何實現$nextTick
    前言:本文需要一定的事件循環相關知識,想了解事件循環的小夥伴可以看這裡。本文要弄明白下面兩件事:$nextTick什麼時候執行vue中nextTick與$nextTick區別1.查看源碼中的$nextTick方法Vue.prototype.
  • 什麼是Vue? 如何安裝和使用Vue?
    >Vue、Angular、React一起,被稱之為前端三大主流框架!.prevent - 調用 event.preventDefault()。.stop - 調用 event.stopPropagation()。.self - 只當事件是從偵聽器綁定的元素本身觸發時才觸發回調。
  • 前端面試題——Vue
    Vue 如何去除 URL 中的vue-router 默認使用 hash 模式,所以在路由加載的時候,項目中的 URL 會自帶 「#」。如果不想使用 「#」, 可以使用 vue-router 的另一種模式 history:newRouter({ mode:'history', routes:[]})
  • 35道常見的前端vue面試題
    對於前端來說,儘管css、html、js是主要的基礎知識,但是隨著技術的不斷發展,出現了很多優秀的mv*框架以及小程序框架。因此,對於前端開發者而言,需要對一些前端框架進行熟練掌握。這篇文章我們一起來聊一聊VUE及全家桶的常見面試問題。1、請講述下VUE的MVVM的理解?
  • Vue.js最佳實踐(五招讓你成為Vue.js大師)
    對大部分人來說,掌握Vue.js基本的幾個API後就已經能夠正常地開發前端網站。但如果你想更加高效地使用Vue來開發,成為Vue.js大師,那下面我要傳授的這五招你一定得認真學習一下了。原因是vue-router」智能地」發現這是同一個組件,然後它就決定要復用這個組件,所以你在created函數裡寫的方法壓根就沒執行。
  • 一個超詳細vue無限滾動vue-infinite-scroll插件的配置及使用詳解
    開發中總會遇到這種下拉加載的設計方案,Vue實現下拉加載最佳方案自然是使用vue-infinite-scroll來實現。接下來我們一起看下它的配置及使用方式。假如你的初始內容高度不夠,不足以填滿可滾動的容器的話,你應設為true,這樣會立即執行一次loadMore,會幫你填充一些初始內容。 infinite-scroll-listen-for-event 當事件在Vue實例中發出時,無限滾動將再次檢查。
  • 前端面試題集合
    有什麼限制js的事件機制settimeout的機制遇到過兼容性的問題嗎,要如何處理項目中使用過構建工具嗎平時如何學習前端的,最近在看的一本書內存洩露的排除定位和解決方法垃圾回收機制websocket實現原理http狀態碼301 302的區別,304是啥緩存機制,
  • web前端開發工程師的三種級別
    從2018年開始,用戶體驗感要求不斷提高,小程序作為一種不用下載就可以使用的應用頗受用戶和開發者歡迎。前端工作還不僅僅只是網頁的製作,還有微網站、APP的製作,遊戲製作,例如可以將你開發的Web頁面直接打包成手機使用的APP應用,遊戲的互動界面更是以前端開發技術為主。大規模的公司把這些分得很細,前端到底是個啥:前端其實是個很大的範疇。
  • Vue組件通信的葵花寶典
    vue作為大前端的後起之秀,如今已是前端開發的必備技能,幾乎所有的公司在面試的時候,都默契的增加了一條,有vue開發經驗者優先,可見vue的魅力。vue學習門檻低,易上手,而且生態圈也比較豐富,完全滿足中小企業的需求,作為一名前端開發者,我們必須掌握基本的生存技能,才能在日益變化的前端開發中不被淘汰。
  • 重學鞏固你的Vuejs知識體系(下)
    重學鞏固你的Vuejs知識體系,如果有哪些知識點遺漏,還望在評論中說明,讓我可以及時更新本篇內容知識體系。歡迎點讚收藏!生命周期首先:new Vue(),new一個Vue的實例,Observe data數據查看,init Events綁定事件,created執行created方法,判斷是否有el屬性,如果沒有,vm.
  • 新能源汽車CAN總線Bus Off處理流程
    CAN總線由其高可靠和實時性被廣泛應用於新能源汽車、軌道交通、醫療、工程機械等行業,本文介紹CAN總線關閉對新能源汽車的功能和安全性能產生的影響,並針對工程師關注的問題,提供有效的解決方案。目前新能源汽車整車網絡還是依靠最為成熟的CAN-bus架構,工程師們通過CAN總線讀取車上的車速、轉速等信號可以控制整車上眾多的ECU單元。但是,你知道CAN總線Bus Off會對新能源汽車的功能帶來哪些影響嗎?本文來做詳細分析。為什麼新能源汽車行業離不開CAN總線?