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

Vue中使用和移除總線Bus的注意事項詳解

 更新時間:2023年04月28日 09:57:57   作者:anjushi_  
Vue中的總線Bus是一種通信機制,可用于組件間的數(shù)據(jù)傳遞和事件觸發(fā)。使用時需要注意Bus的命名和定義、監(jiān)聽和觸發(fā)事件的方法、移除和銷毀Bus的時機和方式等問題。合理使用總線Bus可以提高組件的復(fù)用性和可維護(hù)性,但過度依賴可能會導(dǎo)致代碼耦合和難以維護(hù)

初始化并封裝

main.js中對bus進(jìn)行初始化, Bus是一個不具備 DOM 的組件,它具有的僅僅只是它實例方法

Vue.prototype.$bus = new Vue({
  methods: {
    emit(event, ...args) {
      this.$emit(event, ...args);
    },
    on(event, callback) {
      this.$on(event, callback);
    },
    off(event, callback) {
      this.$off(event, callback);
    }
  }
});

主要是用on代替$on,也可以使用簡化的初始化,如下,組件中也帶$即可

Vue.prototype.$bus = new Vue();

組件中可以使用this.$bus可以查看bus的實例

console.log(this.$bus);

發(fā)送事件

兩個參數(shù),前一個是事件標(biāo)識,后一個是發(fā)送的內(nèi)容

this.$bus.emit("radioChange", "test");

接收事件

方式一(推薦)

this.$bus.on('radioChange', this.Aaa);
Aaa(ii){
  console.log("radioChange", ii)
}

方式二(不推薦)

this.$bus.on('radioChange', res => {
  console.log("radioChange", res)
})

移除事件監(jiān)聽

如果不移除,每次進(jìn)入組件都會新建一個bus監(jiān)聽,導(dǎo)致不斷重復(fù)

在組件的beforeDestroy階段執(zhí)行

方式一:只移除本組件的bus監(jiān)聽

beforeDestroy() {
  this.$bus.off("radioChange", this.Aaa);
},

盡管組件 A 和組件 B 的事件處理器名稱可能相同,但它們是不同的函數(shù)實例。這是因為在每個組件中,這些方法都是組件實例的成員。因此,當(dāng)一個組件在銷毀時調(diào)用 off,它不會影響其他組件的事件監(jiān)聽器。

實際上,每個組件都有自己獨立的作用域,this.Aaa() 在組件 A 和組件 B 的上下文中都是指向組件自己的方法。因此,在組件銷毀時使用 this.$bus.off('radioChange', this.Aaa) 只會移除當(dāng)前組件的監(jiān)聽器,不會影響其他組件的監(jiān)聽器。

如果接收事件使用方式二,是無法使用此方法進(jìn)行移除的

方式二

會移除所有事件標(biāo)識為radioChangebus事件監(jiān)聽

this.$bus.off("radioChange");

如果要使用這種方式,需要為每個組件都制定名稱不同的事件標(biāo)識

要避免這種情況,需要為每個組件提供唯一的事件處理函數(shù)(發(fā)送和接收均使用方式一)

方式三

移除全部監(jiān)聽,慎用

this.$bus.off();

實際使用

發(fā)送組件

<template>
  <div class="page-all">
    <el-button @click="sendBus">sendBus</el-button>
    <el-button @click="showA = !showA">Turn showA</el-button>
    <el-row style="height: 300px;">
      <el-col :span="12" v-if="showA">
        <Ar></Ar>
      </el-col>
      <el-col :span="12">
        <Br></Br>
      </el-col>
    </el-row>
  </div>
</template>
<script>
export default {
  data() {
    return {
      showA: true,
    }
  },
  methods: {
    sendBus(){
      // console.log(this.$bus);
      console.log("send");
      this.$bus.emit("radioChange", "test");
    },
  },
  mounted() {},
}
</script>
<style scoped></style>
<style></style>

組件A

<template>
  ...
</template>
<script>
export default {
  data() {
    return {}
  },
  components: {},
  methods: {
    Aaa(ii){
      console.log("radioChange", ii)
    }
  },
  mounted() {
    this.$bus.on('radioChange', this.Aaa);
  },
  beforeDestroy(){
    this.$bus.off("radioChange", this.Aaa);
  },
}
</script>

組件B

<template>
  ...
</template>
<script>
export default {
  ...
  methods: {
    Aaa(ii){
      console.log("radioChange", ii)
    }
  },
  mounted() {
    this.$bus.on('radioChange', this.Aaa);
  },
  beforeDestroy() {
    this.$bus.off("radioChange", this.Aaa);
  },
}
</script>
...

正確測試效果

先發(fā)送radioChange銷毀A組件,發(fā)送radioChange,只有B組件能接收生成A組件,發(fā)送radioChange,A和B都能收到

錯誤測試效果

如果A組件沒有在銷毀前移除事件監(jiān)聽,則經(jīng)過多次組件的銷毀和生成之后,會有多個重復(fù)的事件監(jiān)聽,可能造成內(nèi)存泄漏

到此這篇關(guān)于Vue中使用和移除總線Bus的注意事項詳解的文章就介紹到這了,更多相關(guān)Vue使用和移除總線Bus內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue路由傳參詳細(xì)介紹

    Vue路由傳參詳細(xì)介紹

    這篇文章主要介紹了Vue路由傳參的兩種方式query和params,介紹了query和params區(qū)別與總結(jié),結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • Vuex 入門教程

    Vuex 入門教程

    這篇文章主要介紹了Vuex 入門教程,Vuex 是一個專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式, 那這個 vuex 怎么用呢?就具體來看一下吧
    2018-01-01
  • vue實現(xiàn)拍照或錄像的示例代碼

    vue實現(xiàn)拍照或錄像的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何利用vue實現(xiàn)拍照或錄像的功能,文中的示例代碼講解詳細(xì),具有一定的參考價值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-11-11
  • Vue表單及表單綁定方法

    Vue表單及表單綁定方法

    今天小編就為大家分享一篇Vue表單及表單綁定方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue3實現(xiàn)按鈕權(quán)限管理的項目實踐

    vue3實現(xiàn)按鈕權(quán)限管理的項目實踐

    在做后臺管理系統(tǒng)時,經(jīng)常會有權(quán)限管理的功能,本文主要介紹了vue3實現(xiàn)按鈕權(quán)限管理的項目實踐,具有一定的參考價值,感興趣的可以了解一下
    2023-08-08
  • 關(guān)于TypeScript的踩坑記錄

    關(guān)于TypeScript的踩坑記錄

    這篇文章主要介紹了關(guān)于TypeScript的踩坑記錄,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • electron-vue+electron-updater實現(xiàn)自動更新(步驟源碼)

    electron-vue+electron-updater實現(xiàn)自動更新(步驟源碼)

    這篇文章主要介紹了electron-vue+electron-updater實現(xiàn)自動更新,步驟源碼包括autoUpdater.js操控更新js文件,main.js也就是package.json內(nèi)的main指向的js文件,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • vue-router 源碼之實現(xiàn)一個簡單的 vue-router

    vue-router 源碼之實現(xiàn)一個簡單的 vue-router

    這篇文章主要介紹了vue-router 源碼之實現(xiàn)一個簡單的 vue-router,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • 使用Vue動態(tài)生成form表單的實例代碼

    使用Vue動態(tài)生成form表單的實例代碼

    這篇文章主要介紹了使用Vue動態(tài)生成form表單的實例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-04-04
  • Vue實現(xiàn)路由跳轉(zhuǎn)至外界頁面

    Vue實現(xiàn)路由跳轉(zhuǎn)至外界頁面

    這篇文章主要介紹了Vue實現(xiàn)路由跳轉(zhuǎn)至外界頁面方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評論