Vue父子組件及祖先后代組件間傳值

組件間傳值
  • props愚铡、$emit
  • $attrs突勇、$listeners
  • provide健芭、inject
  • vuex(暫不展開)

一奸汇、父子組件間傳值

(1)父組件向子組件傳值(通過 props 屬性)
  • 父組件直接在子組件標(biāo)簽上傳值
<div>
    <child :value='message'><child>
</div>
import Child from './Child.vue'
components: {
    Child
},
  • 子組件通過 this.value 來獲取值
// 定義屬性
props: [ 'value' ],
created() {
    let msg = this.value
    console.log(msg)
}
(2)子組件向父組件傳值(通過 emit 事件)
  • 子組件
<div @click="confirm">確定</div>
confirm() {
    this.$emit('confirm', this.value);
},
  • 父組件

通過 @confirm="onConfirm" 把子組件的事件傳遞給父組件的自定義事件

<div>
    <child
        :value="message"
        @confirm="onConfirm">
    </child>
</div>
onConfirm (value) {
    let msg = value;
    console.log(msg);
},

二施符、祖先后代組件間傳值

使用【$attrs往声、$listeners】【provide、inject】

如果我們有:A組件(父) -> B組件(子) -> C組件(孫)戳吝,而我們只是想把A組件的信息傳遞給C組件浩销,如果使用props來傳遞信息,雖然能夠?qū)崿F(xiàn)听哭,但是代碼不夠美觀慢洋。在vue2.4中,為了解決該需求陆盘,引入了$attrs 和 $listenersinheritAttrs(默認(rèn)true普筹,標(biāo)簽元素中是否繼承父組件傳遞過來的屬性)。

(1)$attrs隘马、$listeners

$attrs包含了父作用域中非 props 特性綁定的屬性 (class 和 style 除外)太防。它可以通過 v-bind="$attrs" 將屬性傳入內(nèi)部組件。
$props包含了父作用域中 props 特性綁定的屬性 (class 和 style 除外)酸员。
$listeners包含了父作用域中 (不含 .native 修飾器的) v-on 事件監(jiān)聽器杏头。它可以通過 v-on="$listeners" 將事件監(jiān)聽指向這個(gè)組件內(nèi)的子組件。

  • 父組件
<div id="app">
    <!-- 父組件調(diào)用子組件 -->
    <child :name="111" :age="18" :city="'北京'" @ffunc="fatherFunction"></child>
</div>
function fatherFunction() {
    console.log('父組件 function!!!')
}
  • 子組件
<div>
    <!-- 子組件通過$attrs獲取屬性值 -->
    姓名:{{ $props.name }} - 年齡:{{ $attrs.age }} - 城市:{{ $attrs.city }}
    <!-- 子組件通過 v-bind="$attrs" 將屬性傳入內(nèi)部組件沸呐,通過 v-on="$listeners" 將事件監(jiān)聽指向這個(gè)組件內(nèi)的子組件 -->
    <son :msg="333" v-bind="$attrs" v-on="$listeners"></son>
</div>
inheritAttrs: true, // 標(biāo)簽元素中是否繼承父組件傳遞過來的屬性
props: [ 'name' ],
created() {
    console.log(this.$attrs, this.$props);
    this.$emit('ffunc')
}
  • 孫組件
<div>
    <!-- 孫子組件通過$attrs獲取屬性值 -->
    消息:{{ $props.msg }} - 年齡:{{ $attrs.age }}
</div>
inheritAttrs: false, // 標(biāo)簽元素中是否繼承父組件傳遞過來的屬性
props: [ 'msg' ],
created() {
    console.log(this.$attrs, this.$props);
    this.$emit('ffunc')
}

inheritAttrs(默認(rèn)true醇王,標(biāo)簽元素中是否繼承父組件傳遞過來的屬性)

WX20210618-181158@2x.png

(2)provide、inject

假如有一些深度嵌套的組件崭添,而深層的子組件只需要父組件的部分內(nèi)容寓娩。在這種情況下,如果仍然將 prop 沿著組件鏈逐級(jí)傳遞下去呼渣,可能會(huì)很麻煩棘伴。

對(duì)于這種情況,我們可以使用一對(duì) provide 和 inject屁置。無論組件層次結(jié)構(gòu)有多深焊夸,父組件都可以作為其所有子組件的依賴提供者。這個(gè)特性有兩個(gè)部分:父組件有一個(gè) provide 選項(xiàng)來提供數(shù)據(jù)蓝角,子組件有一個(gè) inject 選項(xiàng)來開始使用這些數(shù)據(jù)阱穗。

  • 父組件
<div id="app">
    <!-- 父組件 -->
    <child></child>
</div>
data () {
    return {
       name: '我是父組件的數(shù)據(jù)',
       age: '',
       city: ''
    }
},
provide() { // 父組件提供數(shù)據(jù)(只需要name字段數(shù)據(jù))
    return {
       user: this.name
    }
},
  • 子組件
 <son></son>
  • 孫組件
<div>
    獲取父組件的數(shù)據(jù):{{ user }} 
</div>
inject: ['user'], // 子組件使用數(shù)據(jù)
created() {
    console.log(this.user)
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市使鹅,隨后出現(xiàn)的幾起案子揪阶,更是在濱河造成了極大的恐慌,老刑警劉巖患朱,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鲁僚,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)冰沙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門侨艾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人拓挥,你說我怎么就攤上這事蒋畜。” “怎么了撞叽?”我有些...
    開封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵姻成,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我愿棋,道長(zhǎng)科展,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任糠雨,我火速辦了婚禮才睹,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘甘邀。我一直安慰自己琅攘,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開白布松邪。 她就那樣靜靜地躺著坞琴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪逗抑。 梳的紋絲不亂的頭發(fā)上剧辐,一...
    開封第一講書人閱讀 49,031評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音邮府,去河邊找鬼荧关。 笑死,一個(gè)胖子當(dāng)著我的面吹牛褂傀,可吹牛的內(nèi)容都是我干的忍啤。 我是一名探鬼主播,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼仙辟,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼同波!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起欺嗤,我...
    開封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤参萄,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后煎饼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡校赤,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年吆玖,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了筒溃。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡虚茶,死狀恐怖歪架,靈堂內(nèi)的尸體忽然破棺而出峦剔,到底是詐尸還是另有隱情,我是刑警寧澤歪玲,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站掷匠,受9級(jí)特大地震影響滥崩,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜讹语,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一钙皮、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧顽决,春花似錦短条、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至赋访,卻和暖如春屹蚊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背进每。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工汹粤, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人田晚。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓嘱兼,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親贤徒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子芹壕,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345