詳解vue之自行實(shí)現(xiàn)派發(fā)與廣播(dispatch與broadcast)
要解決的問題
主要針對(duì)組件之間的跨級(jí)通信
為什么要自己實(shí)現(xiàn)dispatch與broadcast?
因?yàn)樵谧霆?dú)立組件開發(fā)或庫(kù)時(shí),最好是不依賴第三方庫(kù)
為什么不使用provide與inject?
因?yàn)樗氖褂脠?chǎng)景,主要是子組件獲取上級(jí)組件的狀態(tài),跨級(jí)組件間建立了一種主動(dòng)提供與依賴注入的關(guān)系。
然后有兩種場(chǎng)景它不能很好的解決:
父組件向子組件(支持跨級(jí))傳遞數(shù)據(jù);
子組件向父組件(支持跨級(jí))傳遞數(shù)據(jù)。
代碼如下:
emitter.js
function broadcast(componentName, eventName, params) {
this.$children.forEach(child => {
const name = child.$options.name;
if (name === componentName) {
child.$emit.apply(child, [eventName].concat(params));
} else {
// todo 如果 params 是空數(shù)組,接收到的會(huì)是 undefined
broadcast.apply(child, [componentName, eventName].concat([params]));
}
});
}
export default {
methods: {
dispatch(componentName, eventName, params) {
let parent = this.$parent || this.$root;
let name = parent.$options.name;
while (parent && (!name || name !== componentName)) {
parent = parent.$parent;
if (parent) {
name = parent.$options.name;
}
}
if (parent) {
parent.$emit.apply(parent, [eventName].concat(params));
}
},
broadcast(componentName, eventName, params) {
broadcast.call(this, componentName, eventName, params);
}
}
};
parent.vue
<template>
<div>
<h1>我是父組件</h1>
<button @click="handleClick">觸發(fā)事件</button> <child />
</div>
</template>
<script>
import Emitter from "@/mixins/emitter.js";
import Child from "./child";
export default {
name: "componentA",
mixins: [Emitter],
created() {
this.$on("child-to-p", this.handleChild);
},
methods: {
handleClick() {
this.broadcast("componentB", "on-message", "Hello Vue.js");
},
handleChild(val) {
alert(val);
}
},
components: {
Child
}
};
</script>
child.vue
<template>
<div>我是子組件</div>
</template>
<script>
import Emitter from "@/mixins/emitter.js";
export default {
name: "componentB",
mixins: [Emitter],
created() {
this.$on("on-message", this.showMessage);
this.dispatch("componentA", "child-to-p", "hello parent");
},
methods: {
showMessage(text) {
window.alert(text);
}
}
};
</script>
這樣就能實(shí)現(xiàn)跨級(jí)組件自定義通信了,但是,要注意其中一個(gè)問題:訂閱必須先于發(fā)布,也就是說先有on再有emit
父子組件渲染順序,實(shí)例創(chuàng)建順序
子組件先于父組件前渲染,所以在子組的mounted派發(fā)事件時(shí),在父組件中的mounte中是監(jiān)聽不到的。
而父組件的create是先于子組件的,所以可以在父組件中的create可以監(jiān)聽到
到此這篇關(guān)于詳解vue之自行實(shí)現(xiàn)派發(fā)與廣播(dispatch與broadcast)的文章就介紹到這了,更多相關(guān)vue 派發(fā)與廣播內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Vue SPA單頁(yè)應(yīng)用首屏優(yōu)化實(shí)踐
- Vue實(shí)現(xiàn)boradcast和dispatch的示例
- vue-cli單頁(yè)面預(yù)渲染seo-prerender-spa-plugin操作
- vuex中store存儲(chǔ)store.commit和store.dispatch的用法
- Vue SPA 初次進(jìn)入加載動(dòng)畫實(shí)現(xiàn)代碼
- Vue實(shí)現(xiàn)數(shù)據(jù)表格合并列rowspan效果
- vue spa應(yīng)用中的路由緩存問題與解決方案
- 解決Vue+Electron下Vuex的Dispatch沒有效果問題
- VUE解決微信簽名及SPA微信invalid signature問題(完美處理)
- 詳解vuex中action何時(shí)完成以及如何正確調(diào)用dispatch的思考
- Vue SPA 首屏優(yōu)化方案
相關(guān)文章
Vue實(shí)現(xiàn)dom元素拖拽并限制移動(dòng)范圍的操作代碼
這篇文章主要介紹了Vue實(shí)現(xiàn)dom元素拖拽并限制移動(dòng)范圍的操作代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-12-12
vue進(jìn)行下載與處理二進(jìn)制流文件的方法詳解
這篇文章主要為大家詳細(xì)介紹了vue如何實(shí)現(xiàn)將后端返回的二進(jìn)制流進(jìn)行處理并實(shí)現(xiàn)下載,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12
在vue項(xiàng)目中使用element-ui的Upload上傳組件的示例
本篇文章主要介紹了在vue項(xiàng)目中使用element-ui的Upload上傳組件的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-02-02
vue3中實(shí)現(xiàn)文本顯示省略號(hào)和tooltips提示框的方式詳解
在?B?端業(yè)務(wù)中,我們經(jīng)常會(huì)遇到文本內(nèi)容超出容器區(qū)域需顯示省略號(hào)的需求,當(dāng)鼠標(biāo)移入文本時(shí),會(huì)出現(xiàn)?Tooltip?顯示完整內(nèi)容,最近,我也遇到了這樣的場(chǎng)景,接下來給大家介紹vue3中實(shí)現(xiàn)文本顯示省略號(hào)和tooltips提示框的方式,需要的朋友可以參考下2024-04-04
如何用vue2+element-ui實(shí)現(xiàn)多行行內(nèi)表格編輯
最近開發(fā)項(xiàng)目,關(guān)于表格的數(shù)據(jù)操作比較多,這個(gè)地方個(gè)人覺得比較難搞,特此記錄一下,這篇文章主要給大家介紹了關(guān)于如何用vue2+element-ui實(shí)現(xiàn)多行行內(nèi)表格編輯的相關(guān)資料,需要的朋友可以參考下2024-08-08
electron-vue?項(xiàng)目添加啟動(dòng)loading動(dòng)畫的實(shí)現(xiàn)思路
electron-vue腳手架搭建的項(xiàng)目,在開發(fā)階段可能你注意不到項(xiàng)目啟動(dòng)慢的問題,但是在build?生成的exe可執(zhí)行文件,啟動(dòng)后,要反應(yīng)很久才能進(jìn)入到app.vue?中加載的頁(yè)面,體驗(yàn)性很差,本文給大家介紹electron?vue啟動(dòng)動(dòng)畫效果的實(shí)例代碼,感興趣的朋友一起看看吧2022-01-01

