Vue框架提供了許多機(jī)制來方便我們實(shí)現(xiàn)組件間通信,其中一個重要的機(jī)制就是Event Bus。Event Bus是Vue實(shí)例的一個全局事件中心,可以用于父子組件、兄弟組件之間進(jìn)行通信。其中,$emit方法可以觸發(fā)一個自定義事件,并向事件監(jiān)聽器傳入?yún)?shù)。$on方法可以監(jiān)聽一個自定義事件,并在事件觸發(fā)時(shí)執(zhí)行相關(guān)處理。
在實(shí)際開發(fā)中,我們一般會定義一些自定義事件來進(jìn)行業(yè)務(wù)邏輯的處理。但是,有些情況下,我們需要在嵌套的組件間傳遞事件。這時(shí),一個比較好的方案就是使用提供給每個Vue實(shí)例的$dispatch方法。
export default { methods: { handleClick() { this.$dispatch("custom-event", argument1, argument2); } } };
使用$dispatch方法可以向當(dāng)前組件的父級派發(fā)一個自定義事件,并傳遞一些額外的參數(shù)。當(dāng)然,我們需要在父級的組件中定義監(jiān)聽事件的處理函數(shù)。
Vue.component("parent-component", { template: "", mounted() { this.$on("custom-event", (argument1, argument2) =>{ // 在此處執(zhí)行自定義事件的處理邏輯 }); } });
上面的代碼中,當(dāng)子組件調(diào)用$dispatch方法時(shí),父組件定義的事件監(jiān)聽函數(shù)就會被觸發(fā),從而完成了組件間的通信。
需要注意的是,$dispatch方法只能向當(dāng)前組件的父級派發(fā)自定義事件,而且一般情況下,我們不會將同一個自定義事件在同一組件樹中的多個層級間進(jìn)行傳遞,因?yàn)檫@樣會導(dǎo)致代碼的可讀性變差。