vue中bus的使用及踩坑解決
創(chuàng)建一個js文件
import Vue from "Vue" export default new Vue
我們可以直接在要使用的頁面中引用使用
import bus from '@/assets/js/eventBus.js'; bus.$emit("info", "123") // 使用 bus.$on("info", (val) => { // 接收 console.log("info val", val); })
也可以 main.js中引用定義:
import Bus from '@/assets/js/eventBus.js'; Vue.prototype.$bus = Bus; //注意這里的Vue是我上面引入的vue import Vue from 'vue' this.$bus.$emit("vaPage",value); //很像父子之間傳值的方法 this.$bus.$on("vaPage", v =>{ //vaPage傳的時候的key是什么接收就必須是什么 console.log(v); //v是傳來的值,可以接收多個參數(shù) })
正常的通訊上面就已經(jīng)完成了,但是還有一個問題那就是如果接受的頁面不存在了,還是會繼續(xù)執(zhí)行bus.$on,所以我們需要再不需要的時候或者頁面銷毀時將bus銷毀
beforDestroy(){ this.$bus.$off("vaPage"); //當(dāng)這個組件銷毀的時候bus也跟著一起銷毀 bus.$off("info") // 或者 }
但是如果是有個頁面通訊多個頁面通用一個方法我們又該怎么辦呢?比如一個tab切換,里面分別是不同的內(nèi)容,但是點擊了之后有一個詳情需要聯(lián)動,如下圖:
不可能點擊一個定義一個方法,詳情接受所有方法, 只能是都是用一個方法然后通過傳遞特定的標(biāo)識來進行處理!
那么當(dāng)有顯示隱藏功能時就會發(fā)現(xiàn),頁面沒有了正常來說不應(yīng)該再走該頁面接收的方法了,但是現(xiàn)實情況是一直在調(diào)用,所以使用bus.$off("info")銷毀方法是不對的,bus是一個全局的,如果銷毀了會導(dǎo)致頁面的其他功能不可用。所以想了一個折中的方法暫時解決該問題
data() { return { lovk: true, // 定義一個變量 } }, // 在銷毀前解綁bus beforeDestroy() { this.lovk = false console.log("beforeDestroy", this.lovk) }, mounted() { bus.$on("info", (val) => { if (this.lovk) { // 如果this.lovk為true,說明該頁面存在需要執(zhí)行里面的方法,否則就不執(zhí)行 console.log("info val", val); } }) }, // 那么有人會說為什么不直接將整個bus.$on()包裹進去呢?如下列: mounted() { if (this.lovk) { // 這樣寫都不會觸發(fā)了不是更好嗎? bus.$on("info", (val) => { console.log("info val", val); }) } }, // 其實是不可行的,實驗一下你會發(fā)現(xiàn),當(dāng)你頁面消失在顯示后bus.$on()方法不執(zhí)行了
bus還有很多很多坑需要我們?nèi)プ⒁?,所以?jǐn)慎使用bus,暫時就介紹這么多!
到此這篇關(guān)于vue中bus的使用及踩坑解決的文章就介紹到這了,更多相關(guān)vue bus內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
富文本編輯器quill.js?開發(fā)之自定義插件示例詳解
這篇文章主要為大家介紹了富文本編輯器quill.js?開發(fā)之自定義插件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08vue 動態(tài)添加/刪除dom元素節(jié)點的操作代碼
這篇文章主要介紹了vue 動態(tài)添加/刪除dom元素,需要在點擊添加時,增加一行key/value的輸入框;點擊垃圾桶圖標(biāo)時,刪除對應(yīng)行,本文結(jié)合實例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下2022-12-12