咱們接着上文繼續,本文咱們講解兄弟組件的通訊,項目結構仍是跟上文同樣.html
在src/assets目錄下創建文件EventHandler.js,該文件的做用在於給同級組件之間傳遞事件vue
EventHandler.js代碼:jquery
1 import Vue from 'Vue'; 2 export default new Vue();
2,在Components目錄下新建一個組件Brother1.vueapp
1 <template> 2 <div> 3 <h3>Z國: ghostwu</h3> 4 <input v-on:click="send" type="button" value="發送"> 5 <p>{{msg}}</p> 6 </div> 7 </template> 8 <script> 9 import EventHandler from '../assets/EventHandler.js'; 10 export default { 11 data(){ 12 return { 13 msg : '' 14 } 15 }, 16 methods : { 17 send(){ 18 EventHandler.$emit( 'myDefineEv', "ghostwu向島國發射了一顆原子彈" ); 19 } 20 }, 21 mounted (){ 22 let _this = this; 23 EventHandler.$on( "RDefineEv", function( data ){ 24 _this.msg = data; 25 } ); 26 } 27 } 28 </script>
。經過EventHandler.$emit發送一個自定義事件myDefineEv函數
。經過mouted【至關於jquery的ready, 原生js的onload】,這個是vue生命週期的鉤子函數, 用於在頁面加載完成以後執行代碼,在這裏就是接收RDefineEv事件( Brother2.vue定義的 )this
2,在Components目錄下新建一個組件Brother2.vuespa
1 <template> 2 <div> 3 <h3>R國:八嘎</h3> 4 {{msg}} 5 <input v-on:click="defend" type="button" value="防護"> 6 </div> 7 </template> 8 <script> 9 import EventHandler from '../assets/EventHandler.js'; 10 export default { 11 data(){ 12 return { 13 msg : '' 14 } 15 }, 16 methods : { 17 defend(){ 18 EventHandler.$emit( 'RDefineEv', "島國採用了高科技反原子彈系統" ); 19 } 20 }, 21 mounted(){ 22 let _this = this; 23 EventHandler.$on( "myDefineEv", function( data ){ 24 _this.msg = data; 25 } ); 26 } 27 } 28 </script>
。點擊按鈕發送RDefineEv事件code
。文檔ready的時候,接收myDefineEv(Brother1.vue)出發的自定義事件component
3、在App.vue中調用兩個同級組件htm
1 <template> 2 <div id="app"> 3 <Brother1></Brother1> 4 <Brother2></Brother2> 5 </div> 6 </template> 7 8 <script> 9 import Brother1 from './components/Brother1.vue'; 10 import Brother2 from './components/Brother2.vue'; 11 12 export default { 13 components : { 14 Brother1, 15 Brother2 16 } 17 } 18 </script>
小結: