欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中bus的使用及踩坑解決

 更新時(shí)間:2023年08月30日 10:27:41   作者:小皮皮不皮  
這篇文章主要為大家詳細(xì)介紹了vue中bus的相關(guān)使用以及涉及到的問(wèn)題與解決,文中的示例代碼簡(jiǎn)潔易懂,感興趣的小伙伴可以跟隨小編一起了解一下

創(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)文章

  • vuejs簡(jiǎn)單驗(yàn)證碼功能完整示例

    vuejs簡(jiǎn)單驗(yàn)證碼功能完整示例

    這篇文章主要介紹了vuejs簡(jiǎn)單驗(yàn)證碼功能,結(jié)合完整實(shí)例形式分析了vue.js驗(yàn)證碼的生成、顯示、校驗(yàn)等相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01
  • vue跳轉(zhuǎn)同一個(gè)路由參數(shù)不同的問(wèn)題

    vue跳轉(zhuǎn)同一個(gè)路由參數(shù)不同的問(wèn)題

    這篇文章主要介紹了vue跳轉(zhuǎn)同一個(gè)路由參數(shù)不同的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue頁(yè)面圖片不顯示問(wèn)題解決方案

    vue頁(yè)面圖片不顯示問(wèn)題解決方案

    這篇文章主要介紹了vue頁(yè)面圖片不顯示問(wèn)題解決方案,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • 基于vue封裝一個(gè)安全鍵盤(pán)組件

    基于vue封裝一個(gè)安全鍵盤(pán)組件

    大部分中文應(yīng)用彈出的默認(rèn)鍵盤(pán)是簡(jiǎn)體中文輸入法鍵盤(pán),在輸入用戶(hù)名和密碼的時(shí)候,如果使用簡(jiǎn)體中文輸入法鍵盤(pán),用戶(hù)的輸入記錄會(huì)被緩存下來(lái)所以我們需要一個(gè)安全鍵盤(pán),本文給大家介紹了如何基于vue封裝一個(gè)安全鍵盤(pán)組件,需要的朋友可以參考下
    2023-12-12
  • vue雙向綁定數(shù)據(jù)限制長(zhǎng)度的方法

    vue雙向綁定數(shù)據(jù)限制長(zhǎng)度的方法

    這篇文章主要為大家詳細(xì)介紹了vue雙向綁定數(shù)據(jù)限制長(zhǎng)度的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • vue3 實(shí)現(xiàn)牙位圖選擇器的實(shí)例代碼

    vue3 實(shí)現(xiàn)牙位圖選擇器的實(shí)例代碼

    這篇文章主要介紹了vue3 實(shí)現(xiàn)牙位圖選擇器的實(shí)例代碼,代碼簡(jiǎn)單易懂,需要的朋友參考下吧
    2025-04-04
  • 深入淺析Vue中的 computed 和 watch

    深入淺析Vue中的 computed 和 watch

    computed 計(jì)算屬性是通過(guò)屬性計(jì)算得來(lái)的屬性,watch屬性變化,就會(huì)觸發(fā)監(jiān)聽(tīng)的函數(shù)。下面通過(guò)本文給大家介紹Vue中的 computed 和 watch,感興趣的朋友一起看看吧
    2018-06-06
  • 富文本編輯器quill.js?開(kāi)發(fā)之自定義插件示例詳解

    富文本編輯器quill.js?開(kāi)發(fā)之自定義插件示例詳解

    這篇文章主要為大家介紹了富文本編輯器quill.js?開(kāi)發(fā)之自定義插件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • vue 動(dòng)態(tài)添加/刪除dom元素節(jié)點(diǎn)的操作代碼

    vue 動(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-12
  • vue+webpack實(shí)現(xiàn)異步組件加載的方法

    vue+webpack實(shí)現(xiàn)異步組件加載的方法

    下面小編就為大家分享一篇vue+webpack實(shí)現(xiàn)異步組件加載的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02

最新評(píng)論