溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Vue2.0基于vue-cli+webpack同級(jí)組件之間的通信教程(推薦)

發(fā)布時(shí)間:2020-10-02 05:42:27 來(lái)源:腳本之家 閱讀:199 作者:ghostwu 欄目:web開(kāi)發(fā)

我們接著上文繼續(xù),本文我們講解兄弟組件的通信,項(xiàng)目結(jié)構(gòu)還是跟上文一樣.

在src/assets目錄下建立文件EventHandler.js,該文件的作用在于給同級(jí)組件之間傳遞事件

EventHandler.js代碼:

import Vue from 'Vue';
export default new Vue();

1,在Components目錄下新建一個(gè)組件Brother1.vue

<template>
 <div>
  <h4>Z國(guó): ghostwu</h4>
  <input v-on:click="send" type="button" value="發(fā)送">
  <p>{{msg}}</p>
 </div>
</template>
<script>
 import EventHandler from '../assets/EventHandler.js';
 export default {
  data(){
   return {
    msg : ''
   }
  },
  methods : {
   send(){
    EventHandler.$emit( 'myDefineEv', "ghostwu向島國(guó)發(fā)射了一顆原子彈" );
   }
  },
  mounted (){
   let _this = this;
   EventHandler.$on( "RDefineEv", function( data ){
    _this.msg = data;
   } );
  }
 }
</script>

。通過(guò)EventHandler.$emit發(fā)送一個(gè)自定義事件myDefineEv

。通過(guò)mouted【相當(dāng)于jquery的ready, 原生js的onload】,這個(gè)是vue生命周期的鉤子函數(shù), 用于在頁(yè)面加載完成之后執(zhí)行代碼,在這里就是接收RDefineEv事件( Brother2.vue定義的 )

2,在Components目錄下新建一個(gè)組件Brother2.vue

<template>
 <div>
  <h4>R國(guó):八嘎</h4>
  {{msg}}
  <input v-on:click="defend" type="button" value="防御">
 </div>
</template>
<script>
 import EventHandler from '../assets/EventHandler.js';
 export default {
  data(){
   return {
    msg : ''
   }
  },
  methods : {
   defend(){
     EventHandler.$emit( 'RDefineEv', "島國(guó)采用了高科技反原子彈系統(tǒng)" );
   }
  },
  mounted(){
   let _this = this;
   EventHandler.$on( "myDefineEv", function( data ){
    _this.msg = data;
   } );
  }
 }
</script>

。點(diǎn)擊按鈕發(fā)送RDefineEv事件

。文檔ready的時(shí)候,接收myDefineEv(Brother1.vue)出發(fā)的自定義事件

三、在App.vue中調(diào)用兩個(gè)同級(jí)組件

<template>
 <div id="app">
 <Brother1></Brother1>
 <Brother2></Brother2>
 </div>
</template>

<script>
 import Brother1 from './components/Brother1.vue';
 import Brother2 from './components/Brother2.vue';

 export default {
 components : {
  Brother1,
  Brother2
 }
 }
</script>

小結(jié):

創(chuàng)建一個(gè)事件傳遞中心,例如EventHandler.js,用它作為傳遞消息的中介

在需要傳值的組件中用EventHandler.$emit觸發(fā)一個(gè)自定義事件,并傳遞參數(shù)

在需要接收數(shù)據(jù)的組件中用EventHandler.$on監(jiān)聽(tīng)自定義事件,并在回調(diào)函數(shù)中處理傳遞過(guò)來(lái)的參數(shù)

以上這篇Vue2.0基于vue-cli+webpack同級(jí)組件之間的通信教程(推薦)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI