亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue中bus的使用及踩坑解決

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

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

  • vuejs簡單驗證碼功能完整示例

    vuejs簡單驗證碼功能完整示例

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

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

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

    vue頁面圖片不顯示問題解決方案

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

    基于vue封裝一個安全鍵盤組件

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

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

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

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

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

    深入淺析Vue中的 computed 和 watch

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

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

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

    vue 動態(tài)添加/刪除dom元素節(jié)點的操作代碼

    這篇文章主要介紹了vue 動態(tài)添加/刪除dom元素,需要在點擊添加時,增加一行key/value的輸入框;點擊垃圾桶圖標(biāo)時,刪除對應(yīng)行,本文結(jié)合實例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • vue+webpack實現(xiàn)異步組件加載的方法

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

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

最新評論