Vue事件總線怎么用
1.常見的組件通信方式
- pros:父組件傳子組件
- 自定義事件:子組件傳父組件
- vuex:均可實(shí)現(xiàn)
- 插槽:父組件傳子組件
- pubsub-js:均可實(shí)現(xiàn)(較少用)
- $bus全局事件總線:均可實(shí)現(xiàn)
2.事件總線的介紹
如果咱們的應(yīng)用程序不需要類似Vuex這樣的庫來處理組件之間的數(shù)據(jù)通信,就可以考慮Vue中的事件總線來實(shí)現(xiàn)。它相當(dāng)于一個(gè)全局的倉庫,任何組件都可以去這個(gè)倉庫里獲取事件,它就類似溝通橋梁的概念,就像是所有組件共用相同的事件中心,可以向該中心注冊發(fā)送事件或接收事件,所以組件都可以上下平行的通知其他組件來進(jìn)行通信。
3.事件總線原理
因?yàn)樗薪M件對象都能看到 Vue 原型對象上的屬性和方法,所以我們可以在Vue的原型對象上通過設(shè)定一個(gè)bus對象,Vue.prototype.bus = new Vue(),此時(shí)所有的組件對象都能看到bus屬性對象。
同時(shí)由于Vue 原型對象上包含以下事件處理的方法:
- $on(eventName, listener): 綁定自定義事件監(jiān)聽
- $emit(eventName, data): 分發(fā)自定義事件
- $off(eventName): 解綁自定義事件監(jiān)聽
- $once(eventName, listener): 綁定事件監(jiān)聽, 但只能處理一次
所以我們可以通過組件調(diào)用Vue 原型對象中屬性對象bus的方法來實(shí)現(xiàn)通信。
4.總線的實(shí)現(xiàn)
4.1定義事件總線對象
import Vue from 'vue'
import App from './App.vue'
Vue.config.productionTip = false
//給Vue綁定屬性
Vue.prototype.xyz=100;
// Vue.prototype.$EventBus=vm
new Vue({
beforeCreate(){
//安裝事件總線
Vue.prototype.abc=900;
Vue.prototype.$EventBus=this
},
render: h => h(App),
}).$mount('#app')4.2 向總線發(fā)送事件
語法:this.$EventBus.$emit(發(fā)送的事件名,傳遞的參數(shù))
<!-- -->
<template>
<div id="demo01">
<h1>Demo01組件</h1>
<h2>從Demo02接受的收據(jù):{{msg}}</h2>
<button @click="fasong">發(fā)送數(shù)據(jù)給Demo02</button>
</div>
</template>
<script>
export default {
name: "Demo01",
data () {
return {
msg: ''
}
},
methods: {
test01 (data) {
console.log(data);
this.msg = data
},
fasong () {
this.$EventBus.$emit("send", "我是Demo01頁面");
}
},
mounted () {
// console.log(this);
// 2.接受全局的haha事件
this.$EventBus.$on('haha', this.test01)
}
}
</script>
<style scoped>
#demo01 {
background-color: red;
padding: 20px;
margin-bottom: 20px;
}
</style>4.3接收總線事件
語法:this.$EventBus.$on(監(jiān)聽的事件名, 回調(diào)函數(shù))
<!-- -->
<template>
<div id="demo02">
<h1>Demo02組件</h1>
<button @click="sendData">發(fā)送事件給Demo01</button>
<h2>從Demo01接受的收據(jù):{{msg}}</h2>
</div>
</template>
<script>
export default {
name: "Demo02",
data () {
return {
msg: ''
}
},
methods: {
sendData () {
// 觸發(fā)全局的haha事件
this.$EventBus.$emit("haha", '老王')
},
display (data) {
console.log(data);
this.msg = data
}
},
mounted () {
// console.log(this.abc);
console.log(this.$EventBus);
this.$EventBus.$on("send", this.display)
}
}
</script>
<style scoped>
#demo02 {
background-color: blue;
padding: 20px;
}
</style>
4.4總線事件解綁
語法:this.$EventBus.$off(要移除事件名)
在組件離開,也就是被銷毀前,要將該監(jiān)聽事件給移除,以免下次再重復(fù)創(chuàng)建監(jiān)聽。
beforeDestory () {
//移除事件監(jiān)聽send
this.$EventBus.off("send")
}總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
axios上傳文件錯(cuò)誤:Current?request?is?not?a?multipart?request
最近工作中使用vue上傳文件的時(shí)候遇到了個(gè)問題,下面這篇文章主要給大家介紹了關(guān)于axios上傳文件錯(cuò)誤:Current?request?is?not?a?multipart?request解決的相關(guān)資料,需要的朋友可以參考下2023-01-01
vue3中vue.config.js配置Element-plus組件和Icon圖標(biāo)實(shí)現(xiàn)按需自動(dòng)引入實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于vue3中vue.config.js配置Element-plus組件和Icon圖標(biāo)實(shí)現(xiàn)按需自動(dòng)引入的相關(guān)資料,在Vue 3中可以通過配置vue.config.js文件來進(jìn)行按需自動(dòng)引入,需要的朋友可以參考下2024-02-02
VUE + UEditor 單圖片跨域上傳功能的實(shí)現(xiàn)方法
這篇文章主要介紹了VUE + UEditor 單圖片跨域上傳功能的實(shí)現(xiàn)方法,需要的朋友參考下2018-02-02
關(guān)于vue-admin-template模板連接后端改造登錄功能
這篇文章主要介紹了關(guān)于vue-admin-template模板連接后端改造登錄功能,登陸方法根據(jù)賬號密碼查出用戶信息,根據(jù)用戶id與name生成token并返回,userinfo則是對token進(jìn)行獲取,在查出對應(yīng)值進(jìn)行返回,感興趣的朋友一起看看吧2022-05-05
vue3插槽:el-table表頭插入tooltip及更換表格背景色方式
這篇文章主要介紹了vue3插槽:el-table表頭插入tooltip及更換表格背景色方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06
Vue實(shí)現(xiàn)滑動(dòng)拼圖驗(yàn)證碼功能
這篇文章主要介紹了Vue實(shí)現(xiàn)滑動(dòng)拼圖驗(yàn)證碼功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09

