[js高手之路]Vue2.0基於vue-cli+webpack同級組件之間的通訊教程

咱們接着上文繼續,本文咱們講解兄弟組件的通訊,項目結構仍是跟上文同樣.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>

小結:

  • 建立一個事件傳遞中心,例如EventHandler.js,用它做爲傳遞消息的中介
  • 在須要傳值的組件中用EventHandler.$emit觸發一個自定義事件,並傳遞參數
  • 在須要接收數據的組件中用EventHandler.$on監聽自定義事件,並在回調函數中處理傳遞過來的參數
相關文章
相關標籤/搜索