vue中bus的使用及踩坑解決
創(chuàng)建一個(gè)js文件
import Vue from "Vue" export default new Vue
我們可以直接在要使用的頁(yè)面中引用使用
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傳的時(shí)候的key是什么接收就必須是什么 console.log(v); //v是傳來(lái)的值,可以接收多個(gè)參數(shù) })
正常的通訊上面就已經(jīng)完成了,但是還有一個(gè)問(wèn)題那就是如果接受的頁(yè)面不存在了,還是會(huì)繼續(xù)執(zhí)行bus.$on,所以我們需要再不需要的時(shí)候或者頁(yè)面銷(xiāo)毀時(shí)將bus銷(xiāo)毀
beforDestroy(){ this.$bus.$off("vaPage"); //當(dāng)這個(gè)組件銷(xiāo)毀的時(shí)候bus也跟著一起銷(xiāo)毀 bus.$off("info") // 或者 }
但是如果是有個(gè)頁(yè)面通訊多個(gè)頁(yè)面通用一個(gè)方法我們又該怎么辦呢?比如一個(gè)tab切換,里面分別是不同的內(nèi)容,但是點(diǎn)擊了之后有一個(gè)詳情需要聯(lián)動(dòng),如下圖:
不可能點(diǎn)擊一個(gè)定義一個(gè)方法,詳情接受所有方法, 只能是都是用一個(gè)方法然后通過(guò)傳遞特定的標(biāo)識(shí)來(lái)進(jìn)行處理!
那么當(dāng)有顯示隱藏功能時(shí)就會(huì)發(fā)現(xiàn),頁(yè)面沒(méi)有了正常來(lái)說(shuō)不應(yīng)該再走該頁(yè)面接收的方法了,但是現(xiàn)實(shí)情況是一直在調(diào)用,所以使用bus.$off("info")銷(xiāo)毀方法是不對(duì)的,bus是一個(gè)全局的,如果銷(xiāo)毀了會(huì)導(dǎo)致頁(yè)面的其他功能不可用。所以想了一個(gè)折中的方法暫時(shí)解決該問(wèn)題
data() { return { lovk: true, // 定義一個(gè)變量 } }, // 在銷(xiāo)毀前解綁bus beforeDestroy() { this.lovk = false console.log("beforeDestroy", this.lovk) }, mounted() { bus.$on("info", (val) => { if (this.lovk) { // 如果this.lovk為true,說(shuō)明該頁(yè)面存在需要執(zhí)行里面的方法,否則就不執(zhí)行 console.log("info val", val); } }) }, // 那么有人會(huì)說(shuō)為什么不直接將整個(gè)bus.$on()包裹進(jìn)去呢?如下列: mounted() { if (this.lovk) { // 這樣寫(xiě)都不會(huì)觸發(fā)了不是更好嗎? bus.$on("info", (val) => { console.log("info val", val); }) } }, // 其實(shí)是不可行的,實(shí)驗(yàn)一下你會(huì)發(fā)現(xiàn),當(dāng)你頁(yè)面消失在顯示后bus.$on()方法不執(zhí)行了
bus還有很多很多坑需要我們?nèi)プ⒁?,所以?jǐn)慎使用bus,暫時(shí)就介紹這么多!
到此這篇關(guān)于vue中bus的使用及踩坑解決的文章就介紹到這了,更多相關(guān)vue bus內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue跳轉(zhuǎn)同一個(gè)路由參數(shù)不同的問(wèn)題
這篇文章主要介紹了vue跳轉(zhuǎn)同一個(gè)路由參數(shù)不同的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08vue雙向綁定數(shù)據(jù)限制長(zhǎng)度的方法
這篇文章主要為大家詳細(xì)介紹了vue雙向綁定數(shù)據(jù)限制長(zhǎng)度的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11vue3 實(shí)現(xiàn)牙位圖選擇器的實(shí)例代碼
這篇文章主要介紹了vue3 實(shí)現(xiàn)牙位圖選擇器的實(shí)例代碼,代碼簡(jiǎn)單易懂,需要的朋友參考下吧2025-04-04富文本編輯器quill.js?開(kāi)發(fā)之自定義插件示例詳解
這篇文章主要為大家介紹了富文本編輯器quill.js?開(kāi)發(fā)之自定義插件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08vue 動(dòng)態(tài)添加/刪除dom元素節(jié)點(diǎn)的操作代碼
這篇文章主要介紹了vue 動(dòng)態(tài)添加/刪除dom元素,需要在點(diǎn)擊添加時(shí),增加一行key/value的輸入框;點(diǎn)擊垃圾桶圖標(biāo)時(shí),刪除對(duì)應(yīng)行,本文結(jié)合實(shí)例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下2022-12-12vue+webpack實(shí)現(xiàn)異步組件加載的方法
下面小編就為大家分享一篇vue+webpack實(shí)現(xiàn)異步組件加載的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02