真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

VueEventBus自定義組件事件傳遞

前言

創(chuàng)新互聯(lián)建站主營漠河網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都APP應(yīng)用開發(fā),漠河h5成都微信小程序搭建,漠河網(wǎng)站營銷推廣歡迎漠河等地區(qū)企業(yè)咨詢

組件化應(yīng)用構(gòu)建是Vue的特點之一,因此我們在Vue的實際開發(fā)過程中會經(jīng)常需要封裝自定義組件,以提高開發(fā)的效率。 而組件在大部分情況下并不會孤立的存在,它必然會與父組件和兄弟組件產(chǎn)生數(shù)據(jù)的交互。所以在這里為大家總結(jié)兩種組件數(shù)據(jù)交互的方式:EventBus和利用Vuex框架進行狀態(tài)管理。

我會通過兩種不同的交互方式,它們對于父子組件間數(shù)據(jù)交互和兄弟組件間數(shù)據(jù)交互。

由于篇幅關(guān)系,本文主要介紹EventBus進行數(shù)據(jù)消息傳遞;關(guān)于運用Vuex框架進行狀態(tài)管理在下一篇文章中介紹。

案例介紹

本章節(jié)會有大量的代碼示例,為了讓讀者閱讀輕松,做如下目錄和組件介紹。本章節(jié)主要運用了兩個子組件和一個父組件。

子組件文件名:SearchInput.vueSearchItem.vue

父組件文件名:StateView.vue

目錄結(jié)構(gòu)展示:

Vue EventBus自定義組件事件傳遞

1、SearchInput.vue

組件介紹:一個輸入框,它會onInput方法去監(jiān)聽輸入內(nèi)容,并調(diào)用方法,將輸入框內(nèi)的數(shù)據(jù)傳遞出去。

代碼展示:





SearchItem.vue

組件介紹:一個span,它主要用來接收父組件傳遞的內(nèi)容和接收同胞組件輸入框傳遞的內(nèi)容,并進行展示。

代碼示例:





StateView.vue

組件介紹:父組件,主要展示頁面和加載子組件

代碼示例:





正文

EventBus

1、父組件發(fā)送數(shù)據(jù)給子組件,可以通過子組件定義的 props 自定義屬性,去傳遞數(shù)據(jù)

2、EventBus其實就是通過實例化一個Vue實例,然后通過該實例的 $emit 方法發(fā)送數(shù)據(jù)消息和 $on 方法接收數(shù)據(jù)消息。它適用在子組件發(fā)送消息給父組件或子組件發(fā)送消息給兄弟組件。

我們看下一個下面案例主要展示了:

1、通過 props 父組件(StateView)去為子組件(SearchItem)傳遞數(shù)據(jù);

2、子組件(SearchInput)通過 EventBus 和父組件(StateView)、兄弟組件(SearchItem)傳遞數(shù)據(jù);

目錄結(jié)構(gòu)展示

Vue EventBus自定義組件事件傳遞 

效果展示

Vue EventBus自定義組件事件傳遞

代碼展示:(粗體表示變化部分)

 1、第一步:自定義一個EventBus(SearchEvent.js)

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

在這里我們 new 了一個Vue的實例,并將它輸出。

第二步:子組件通過EventBus發(fā)送數(shù)據(jù)消息





在上面的示例我們主要做了以下事情: 1、導入EventBus

2、通過 @input="sendEvent" 去監(jiān)聽 onInput 事件,并發(fā)現(xiàn)輸入框內(nèi)內(nèi)容有改變時,回調(diào) sendEvent 方法,調(diào)用 EventBus.emit() 方法把數(shù)據(jù)消息發(fā)送出去

第三步父組件(StateView)和子組件(SearchItem)接收數(shù)據(jù)消息

StateView.vue





在上面的示例我們主要做了以下事情:

1、在父組件,我們通過SearchItem的 props 去傳遞了數(shù)據(jù)。

2、通過在組件 mounted 生命周期中調(diào)用 EventBus.on() 方法去接收子組件(SearchInput)的數(shù)據(jù)消息,并對content進行修改值

SearchItem.vue





在上面的示例我們主要做了一事情:

通過在組件 mounted 生命周期中調(diào)用 EventBus.on() 方法去接收子組件(SearchInput)的數(shù)據(jù)消息,并對content進行修改值。

我們可以感受到 SearchInput一發(fā)送數(shù)據(jù)消息,所有注冊接收 search 事件的地方都會接收到數(shù)據(jù)消息

復盤:

1、父組件給子組件進行數(shù)據(jù)傳遞可以通過 props 進行傳遞。

2、子組件給父組件進行消息傳遞或子組件給兄弟組件進行消息傳遞可以通過EventBus去實例化一個Vue,并通過該實例的 $emit$on 方法去傳遞和接收數(shù)據(jù)消息。

3、數(shù)據(jù)消息一旦發(fā)送,所有注冊了接收該數(shù)據(jù)消息的地方都會接收到該數(shù)據(jù)消息。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


本文標題:VueEventBus自定義組件事件傳遞
當前地址:http://weahome.cn/article/pishcp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部