vue父子組件間通信

父子通信目前有四種方式:

1.父組件傳遞數(shù)據(jù)給子組件
父組件數(shù)據(jù)如何傳遞給子組件呢?可以通過(guò)props屬性來(lái)實(shí)現(xiàn)
父組件:

<parent> <child :child-msg="msg"></child>//這里必須要用 - 代替駝峰</parent>data(){ return { msg: [1,2,3] };}

子組件通過(guò)props來(lái)接收數(shù)據(jù):
方式1:
props: ['childMsg']

方式2 :
props: { childMsg: Array //這樣可以指定傳入的類型趁矾,如果類型不對(duì)石咬,會(huì)警告}

props: { childMsg: { type: Array, default: [0,0,0] //這樣可以指定默認(rèn)的值 }}
這樣呢,就實(shí)現(xiàn)了父組件向子組件傳遞數(shù)據(jù).

2.子組件與父組件通信
那么,如果子組件想要改變數(shù)據(jù)呢?這在vue中是不允許的,因?yàn)関ue只允許單向數(shù)據(jù)傳遞绑咱,這時(shí)候我們可以通過(guò)觸發(fā)自定義事件來(lái)通知父組件改變數(shù)據(jù),從而達(dá)到改變子組件數(shù)據(jù)的目的.

使用 v-on 綁定自定義事件
每個(gè) Vue 實(shí)例都實(shí)現(xiàn)了事件接口(Events interface)枢泰,即:
使用 on(eventName) 監(jiān)聽事件 使用emit(eventName) 觸發(fā)事件

父組件可以在使用子組件的地方直接用 v-on 來(lái)監(jiān)聽子組件觸發(fā)的事件描融。

子組件:

<template> <div @click="up"></div></template>methods: { up() { this.$emit('resultChange','hehe'); //主動(dòng)觸發(fā)resultChange方法,'hehe'為向父組件傳遞的數(shù)據(jù) }}

父組件:

<div> <child @on-result-change="mychangHandle" :msg="msg"></child> //監(jiān)聽子組件觸發(fā)的upup事件,然后調(diào)用change方法</div>methods: { mychangHandle(msg) { this.msg = msg; }}

觸發(fā)事件使用駝峰格式的自定義事件名稱衡蚂,在父組件中就可以使用on-evnet-name的形式來(lái)監(jiān)聽窿克。

3.任意組件間通信
如果2個(gè)組件不是父子組件那么如何通信呢?這時(shí)可以通過(guò)eventHub來(lái)實(shí)現(xiàn)通信.
所謂eventHub就是創(chuàng)建一個(gè)事件中心毛甲,相當(dāng)于中轉(zhuǎn)站年叮,可以用它來(lái)傳遞事件和接收事件.
使用一個(gè)空的 Vue 實(shí)例作為中央事件總線:

let Hub = new Vue(); //創(chuàng)建事件中心,注意Hub要放在全局

組件1觸發(fā):

<div @click="eve"></div>methods: { eve() { Hub.$emit('change','hehe'); //Hub觸發(fā)事件 }}

組件2接收:

<div></div>created() { Hub.$on('change', () => { //Hub接收事件 this.msg = 'hehe'; });}
  1. $refs
    盡管有 props 和 events ,但是有時(shí)仍然需要在 JavaScript 中直接訪問(wèn)子組件玻募。為此可以使用 ref 為子組件指定一個(gè)索引 ID 只损。
<div id="parent">
  <user-profile ref="profile"></user-profile>
</div>
var parent = new Vue({ el: '#parent' })
// 訪問(wèn)子組件
var child = parent.$refs.profile

當(dāng) ref 和 v-for 一起使用時(shí), ref 是一個(gè)數(shù)組或?qū)ο笃哌郑鄳?yīng)的子組件跃惫。
refs 只在組件渲染完成后才填充,并且它是非響應(yīng)式的艾栋。它僅僅作為一個(gè)直接訪問(wèn)子組件的應(yīng)急方案——應(yīng)當(dāng)避免在模版或計(jì)算屬性中使用refs 爆存。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蝗砾,隨后出現(xiàn)的幾起案子先较,更是在濱河造成了極大的恐慌,老刑警劉巖悼粮,帶你破解...
    沈念sama閱讀 217,084評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件闲勺,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡扣猫,警方通過(guò)查閱死者的電腦和手機(jī)菜循,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)苞笨,“玉大人债朵,你說(shuō)我怎么就攤上這事∑倌” “怎么了序芦?”我有些...
    開封第一講書人閱讀 163,450評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)粤咪。 經(jīng)常有香客問(wèn)我谚中,道長(zhǎng),這世上最難降的妖魔是什么寥枝? 我笑而不...
    開封第一講書人閱讀 58,322評(píng)論 1 293
  • 正文 為了忘掉前任宪塔,我火速辦了婚禮,結(jié)果婚禮上囊拜,老公的妹妹穿的比我還像新娘某筐。我一直安慰自己,他們只是感情好冠跷,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,370評(píng)論 6 390
  • 文/花漫 我一把揭開白布南誊。 她就那樣靜靜地躺著,像睡著了一般蜜托。 火紅的嫁衣襯著肌膚如雪抄囚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,274評(píng)論 1 300
  • 那天橄务,我揣著相機(jī)與錄音幔托,去河邊找鬼。 笑死蜂挪,一個(gè)胖子當(dāng)著我的面吹牛重挑,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播棠涮,決...
    沈念sama閱讀 40,126評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼攒驰,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了故爵?” 一聲冷哼從身側(cè)響起玻粪,我...
    開封第一講書人閱讀 38,980評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎诬垂,沒(méi)想到半個(gè)月后劲室,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,414評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡结窘,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,599評(píng)論 3 334
  • 正文 我和宋清朗相戀三年很洋,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片隧枫。...
    茶點(diǎn)故事閱讀 39,773評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡喉磁,死狀恐怖谓苟,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情协怒,我是刑警寧澤涝焙,帶...
    沈念sama閱讀 35,470評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站孕暇,受9級(jí)特大地震影響仑撞,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜妖滔,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,080評(píng)論 3 327
  • 文/蒙蒙 一隧哮、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧座舍,春花似錦沮翔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,713評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至岸浑,卻和暖如春搏存,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背矢洲。 一陣腳步聲響...
    開封第一講書人閱讀 32,852評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工璧眠, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人读虏。 一個(gè)月前我還...
    沈念sama閱讀 47,865評(píng)論 2 370
  • 正文 我出身青樓责静,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親盖桥。 傳聞我的和親對(duì)象是個(gè)殘疾皇子灾螃,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,689評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 父往子傳值子頁(yè)面接受方案 default是默認(rèn)值,type是限制類型 vue之父子組件間通信實(shí)例講解(props齿税、...
    yichen_china閱讀 4,249評(píng)論 0 5
  • 組件(Component)是Vue.js最核心的功能彼硫,也是整個(gè)架構(gòu)設(shè)計(jì)最精彩的地方,當(dāng)然也是最難掌握的。...
    六個(gè)周閱讀 5,604評(píng)論 0 32
  • 導(dǎo)語(yǔ) 父子組件通信是常見的組件間通信拧篮。常用的通信方式除了通過(guò)prop單向下行綁定外词渤,還可以用$emit觸發(fā)父組件對(duì)...
    Ryan_a8d5閱讀 168評(píng)論 0 0
  • 父子組件通信 首先說(shuō)一下父子組件。 比如一個(gè)頁(yè)面有三部分組成串绩,如下所示缺虐, 在 Vue 開發(fā)中對(duì)應(yīng)有一個(gè) APP 組...
    大俠咕咚閱讀 440評(píng)論 1 0
  • vue概述 在官方文檔中,有一句話對(duì)Vue的定位說(shuō)的很明確:Vue.js 的核心是一個(gè)允許采用簡(jiǎn)潔的模板語(yǔ)法來(lái)聲明...
    li4065閱讀 7,215評(píng)論 0 25