Vue中使用和移除總線Bus的注意事項(xiàng)詳解
初始化并封裝
在main.js
中對(duì)bus進(jìn)行初始化, Bus是一個(gè)不具備 DOM 的組件,它具有的僅僅只是它實(shí)例方法
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
,也可以使用簡(jiǎn)化的初始化,如下,組件中也帶$
即可
Vue.prototype.$bus = new Vue();
組件中可以使用this.$bus
可以查看bus的實(shí)例
console.log(this.$bus);
發(fā)送事件
兩個(gè)參數(shù),前一個(gè)是事件標(biāo)識(shí),后一個(gè)是發(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)聽(tīng)
如果不移除,每次進(jìn)入組件都會(huì)新建一個(gè)bus監(jiān)聽(tīng),導(dǎo)致不斷重復(fù)
在組件的beforeDestroy
階段執(zhí)行
方式一:只移除本組件的bus監(jiān)聽(tīng)
beforeDestroy() { this.$bus.off("radioChange", this.Aaa); },
盡管組件 A 和組件 B 的事件處理器名稱可能相同,但它們是不同的函數(shù)實(shí)例。這是因?yàn)樵诿總€(gè)組件中,這些方法都是組件實(shí)例的成員。因此,當(dāng)一個(gè)組件在銷毀時(shí)調(diào)用 off
,它不會(huì)影響其他組件的事件監(jiān)聽(tīng)器。
實(shí)際上,每個(gè)組件都有自己獨(dú)立的作用域,this.Aaa()
在組件 A 和組件 B 的上下文中都是指向組件自己的方法。因此,在組件銷毀時(shí)使用 this.$bus.off('radioChange', this.Aaa)
只會(huì)移除當(dāng)前組件的監(jiān)聽(tīng)器,不會(huì)影響其他組件的監(jiān)聽(tīng)器。
如果接收事件使用方式二,是無(wú)法使用此方法進(jìn)行移除的
方式二
會(huì)移除所有事件標(biāo)識(shí)為radioChange
的bus
事件監(jiān)聽(tīng)
this.$bus.off("radioChange");
如果要使用這種方式,需要為每個(gè)組件都制定名稱不同的事件標(biāo)識(shí)
要避免這種情況,需要為每個(gè)組件提供唯一的事件處理函數(shù)(發(fā)送和接收均使用方式一)
方式三
移除全部監(jiān)聽(tīng),慎用
this.$bus.off();
實(shí)際使用
發(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> ...
正確測(cè)試效果
先發(fā)送radioChange銷毀A組件,發(fā)送radioChange,只有B組件能接收生成A組件,發(fā)送radioChange,A和B都能收到
錯(cuò)誤測(cè)試效果
如果A組件沒(méi)有在銷毀前移除事件監(jiān)聽(tīng),則經(jīng)過(guò)多次組件的銷毀和生成之后,會(huì)有多個(gè)重復(fù)的事件監(jiān)聽(tīng),可能造成內(nèi)存泄漏
到此這篇關(guān)于Vue中使用和移除總線Bus的注意事項(xiàng)詳解的文章就介紹到這了,更多相關(guān)Vue使用和移除總線Bus內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue3實(shí)現(xiàn)按鈕權(quán)限管理的項(xiàng)目實(shí)踐
在做后臺(tái)管理系統(tǒng)時(shí),經(jīng)常會(huì)有權(quán)限管理的功能,本文主要介紹了vue3實(shí)現(xiàn)按鈕權(quán)限管理的項(xiàng)目實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08electron-vue+electron-updater實(shí)現(xiàn)自動(dòng)更新(步驟源碼)
這篇文章主要介紹了electron-vue+electron-updater實(shí)現(xiàn)自動(dòng)更新,步驟源碼包括autoUpdater.js操控更新js文件,main.js也就是package.json內(nèi)的main指向的js文件,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-10-10vue-router 源碼之實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 vue-router
這篇文章主要介紹了vue-router 源碼之實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 vue-router,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-07-07使用Vue動(dòng)態(tài)生成form表單的實(shí)例代碼
這篇文章主要介紹了使用Vue動(dòng)態(tài)生成form表單的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-04-04Vue實(shí)現(xiàn)路由跳轉(zhuǎn)至外界頁(yè)面
這篇文章主要介紹了Vue實(shí)現(xiàn)路由跳轉(zhuǎn)至外界頁(yè)面方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12