直奔主題!
兄弟組件之間的事件觸發,大概思路是通過父級組件交換數據,watch來監聽觸發事件。
場景是父級組件A同時引用兩個子級組件B,C。點擊B組件中的按鈕執行C組件中的事件。
第一步:父級組件A
<bottom-play :play="playStatus" @playStatus="btmChild"></bottom-play> methods:{ listChild:function(val){//B組件自定義事件 狀態是布爾值 this.playStatus = val; }, btmChild:function(val){//C組件自定義事件 this.btmStatus = val; } }
第二步:子級組件B代碼
props: ['play'],//接受父級傳遞的數據 watch:{//監聽數據 如果改變執行audioPlay函數,audioPlay在methods中定義 play:'audioPlay' } audioPlay:function(){ this.$emit('playStatus',false);//向父級組件傳遞參數 }
第三步:子級組件C代碼
props: ['btmStatus'] ,watch:{ btmStatus:'playList' }
總結就是A組件定義兩個值分別傳遞給B,C。然后B,C組件watch方法監聽數據觸發事件。
以上這篇基于vue 兄弟組件之間事件觸發(詳解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VeVb武林網。
新聞熱點
疑難解答