欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue2.0s中eventBus實(shí)現(xiàn)兄弟組件通信的示例代碼

 更新時(shí)間:2017年10月25日 11:29:13   作者:YuuyaRin  
這篇文章主要介紹了vue2.0s中eventBus實(shí)現(xiàn)兄弟組件通信的示例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

vue1.0中,組件之間的通信主要通過(guò)vm.$dispatch沿著父鏈向上傳播和用vm.$broadcast向下廣播來(lái)實(shí)現(xiàn)。然而在vue2.0中,已經(jīng)廢除了這種用法。

vuex加入后,對(duì)組件之間的通信有了更加清晰的操作,對(duì)于中大型的項(xiàng)目來(lái)說(shuō),一開(kāi)始就把vuex的使用計(jì)劃在內(nèi)是明智的選擇。

然而在一些小型的項(xiàng)目,或者說(shuō)像我這樣寫(xiě)到一半才發(fā)現(xiàn)vue2.0用不了$.broadcast和$dispatch的人來(lái)說(shuō),就需要一個(gè)比較便捷的解決方法。那么,eventBus的作用就體現(xiàn)出來(lái)了。

主要是現(xiàn)實(shí)途徑是在要相互通信的兄弟組件之中,都引入一個(gè)新的vue實(shí)例,然后通過(guò)分別調(diào)用這個(gè)實(shí)例的事件觸發(fā)和監(jiān)聽(tīng)來(lái)實(shí)現(xiàn)通信和參數(shù)傳遞。

這里來(lái)看一個(gè)簡(jiǎn)單的例子:

比如,我們這里有三個(gè)組件,main.vue、click.vue、show.vue。click和show是父組件main下的兄弟組件,而且click是通過(guò)v-for在父組件中遍歷在了多個(gè)列表項(xiàng)中。這里要實(shí)現(xiàn),click組件中觸發(fā)點(diǎn)擊事件后,由show組件將點(diǎn)擊的是哪個(gè)dom元素console出來(lái)。

首先,我們給click組件添加點(diǎn)擊事件

<div class="click" @click.stop.prevent="doClick($event)"></div> 

 想要在doClick()方法中,實(shí)現(xiàn)對(duì)show組件的通信,我們需要新建一個(gè)js文件,來(lái)創(chuàng)建出我們的eventBus,我們把它命名為bus.js

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

這樣我們就創(chuàng)建了一個(gè)新的vue實(shí)例。接下來(lái)我們?cè)赾lick組件和show組件中import它。

import Bus from 'common/js/bus.js'; 

接下來(lái),我們?cè)赿oClick方法中,來(lái)觸發(fā)一個(gè)事件:

methods: { 
  addCart(event) { 
  Bus.$emit('getTarget', event.target);  
  } 
} 

這里我們?cè)赾lick組件中每次點(diǎn)擊,都會(huì)在bus中觸發(fā)這個(gè)名為'getTarget'的事件,并將點(diǎn)擊事件的event.target順著事件傳遞出去。

接著,我們要在show組件中的created()鉤子中調(diào)用bus監(jiān)聽(tīng)這個(gè)事件,并接收參數(shù):

created() { 
    Bus.$on('getTarget', target => { 
      console.log(target); 
    }); 
   } 

這樣,在每次click組件的點(diǎn)擊事件中,就會(huì)把event.target傳遞到show中,并console出來(lái)。

所以eventBus的使用還是非常便捷的,但是如果是中大型項(xiàng)目,通信比較復(fù)雜,還是建議大家直接使用vuex。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue用Object.defineProperty手寫(xiě)一個(gè)簡(jiǎn)單的雙向綁定的示例

    vue用Object.defineProperty手寫(xiě)一個(gè)簡(jiǎn)單的雙向綁定的示例

    這篇文章主要介紹了用Object.defineProperty手寫(xiě)一個(gè)簡(jiǎn)單的雙向綁定的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • vue.js引用背景圖background無(wú)效的3種解決方案

    vue.js引用背景圖background無(wú)效的3種解決方案

    這篇文章主要介紹了vue.js引用背景圖background無(wú)效的3種解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue.js頁(yè)面加載執(zhí)行created,mounted的先后順序說(shuō)明

    vue.js頁(yè)面加載執(zhí)行created,mounted的先后順序說(shuō)明

    這篇文章主要介紹了vue.js頁(yè)面加載執(zhí)行created,mounted的先后順序說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-11-11
  • vue中分割線的實(shí)現(xiàn)方式

    vue中分割線的實(shí)現(xiàn)方式

    這篇文章主要介紹了vue中分割線的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • vue中組件之間相互傳值的6種方法小結(jié)

    vue中組件之間相互傳值的6種方法小結(jié)

    Vue.js?中組件間通信的方法有很多種,這篇文章主要為大家詳細(xì)介紹了6種常見(jiàn)的直接或間接的組件傳值方式,有需要的小伙伴可以參考一下
    2024-01-01
  • Vue中$set()的使用方法場(chǎng)景分析

    Vue中$set()的使用方法場(chǎng)景分析

    由于 Vue 會(huì)在初始化實(shí)例時(shí)進(jìn)行雙向數(shù)據(jù)綁定,使用Object.defineProperty()對(duì)屬性遍歷添加 getter/setter 方法,所以屬性必須在 data 對(duì)象上存在時(shí)才能進(jìn)行上述過(guò)程 ,這樣才能讓它是響應(yīng)的,這篇文章主要介紹了Vue中$set()的使用方法場(chǎng)景分析,需要的朋友可以參考下
    2023-02-02
  • Vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式(超詳細(xì)整理)

    Vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式(超詳細(xì)整理)

    這篇文章給大家詳細(xì)的整理了Vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式,使用vue-router,聲明式-router-link,編程式這三種方法,分別有詳細(xì)的代碼示例,需要的朋友可以參考下
    2023-09-09
  • Element如何實(shí)現(xiàn)loading的方法示例

    Element如何實(shí)現(xiàn)loading的方法示例

    本文主要介紹了Element如何實(shí)現(xiàn)loading的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • vue3 攜帶參數(shù)跳轉(zhuǎn)|router傳參方式

    vue3 攜帶參數(shù)跳轉(zhuǎn)|router傳參方式

    這篇文章主要介紹了vue3 攜帶參數(shù)跳轉(zhuǎn)|router傳參方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • vue3手動(dòng)刪除keepAlive緩存的方法

    vue3手動(dòng)刪除keepAlive緩存的方法

    當(dāng)我們未設(shè)置keepAlive的最大緩存數(shù)時(shí),當(dāng)緩存組件太多,會(huì)導(dǎo)致內(nèi)存溢出,本文給大家介紹了vue3手動(dòng)刪除keepAlive緩存的方法,文中通過(guò)代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03

最新評(píng)論