$attrs奔则、$listeners在Vue中的使用

在多級組件嵌套需要傳遞數(shù)據(jù)時蛮寂,通常會想到的方法是使用vuex或者bus傳值,又或者事件觸發(fā)傳值易茬,但是如果僅僅是傳遞一下數(shù)據(jù)酬蹋,而不做中間的處理,用這幾種方法感覺并不是特別的理想抽莱。所以就有了 attrs /listeners 范抓,通常配合 inheritAttrs 一起使用。

inheritAttrs:默認值為 true食铐。
默認情況下父作用域的不被認作 props 的 attribute 綁定 (attribute bindings) 將會“回退”且作為普通的 HTML attribute 應用在子組件的根元素上匕垫。當撰寫包裹一個目標元素或另一個組件的組件時,這可能不會總是符合預期行為虐呻。通過設置 inheritAttrsfalse象泵,這些默認行為將會被去掉。而通過 (同樣是 2.4 新增的) 實例 property $attrs 可以讓這些 attribute 生效斟叼,且可以通過 v-bind 顯性的綁定到非根元素上偶惠。查 看 官 網(wǎng)

感覺還是挺晦澀難懂的,簡單的說就是 inheritAttrs:true 繼承除props之外的所有屬性朗涩;inheritAttrs:false 只繼承class屬性

attrs:包含了父作用域中不被認為 (且不預期為) props 的特性綁定 (class 和 style 除外)忽孽,并且可以通過 v-bind=”attrs” 傳入內(nèi)部組件。當一個組件沒有聲明任何 props 時谢床,它包含所有父作用域的綁定 (class 和 style 除外)扒腕。

listeners:包含了父作用域中的 (不含 .native 修飾符) v-on 事件監(jiān)聽器。它可以通過 v-on=”listeners” 傳入內(nèi)部組件萤悴。它是一個對象瘾腰,里面包含了作用在這個組件上的所有事件監(jiān)聽器,相當于子組件繼承了父組件的事件覆履。

話不多說蹋盆,咱先上栗子
father.vue組件

<template>
   <child :name="name" :infoObj="infoObj" @updateInfo="updateInfo" />
</template>
<script>
    import Child from '../components/child.vue'
    export default {
        name: 'father',
        components: { Child },
        data () {
            return {
                name: 'Lily',
                infoObj: {
                    from: '上海',
                }
            }
        },
        methods: {
            updateInfo() {
                console.log('update info');
            }
        }
    }
</script>

child.vue 組件:

<template>
    <grand-son :height="height" @addInfo="addInfo" v-bind="$attrs" v-on="$listeners"  />
    // 通過 $listeners 將父作用域中的事件,傳入 grandSon 組件硝全,使其可以獲取到 father 中的事件
</template>
<script>
    import GrandSon from '../components/grandSon.vue'
    export default {
        name: 'child',
        components: { GrandSon },
        props: ['name'],
        data() {
          return {
              height: '180cm',
              weight: '70kg'
          };
        },
        created() {
            console.log(this.$attrs); 
       // 結(jié)果:infoObj, 因為父組件共傳來name, infoObj2個值栖雾,由于name被 props接收了,所以只有infoObj屬性
            console.log(this.$listeners); // updateInfo: f
        },
        methods: {
            addInfo () {
                console.log('add info')
            }
        }
    }
</script>

grandSon.vue 組件:

<template>
    <div>
        {{ $attrs }} --- {{ $listeners }}
    <div>
</template>
<script>
    export default {
        ... ... 
        created() {
            console.log(this.$attrs); // infoObj, height 
            console.log(this.$listeners) // updateInfo: f,  addInfo: f
            this.$emit('updateInfo') // 可以觸發(fā) father 組件中的updateInfo函數(shù)
        }
    }
</script>

總結(jié):這種方式的傳值對我來說不常用伟众,感覺可讀性不是很好析藕。但當你在構(gòu)建一個多層嵌套的組件時,對于組件層級嵌套比較深凳厢,使用props會很繁瑣账胧,或者項目比較小竞慢,不太適合使用 Vuex 的時候,可以考慮用它治泥。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末筹煮,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子居夹,更是在濱河造成了極大的恐慌败潦,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件准脂,死亡現(xiàn)場離奇詭異劫扒,居然都是意外死亡,警方通過查閱死者的電腦和手機狸膏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進店門沟饥,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人环戈,你說我怎么就攤上這事∨炀模” “怎么了院塞?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長性昭。 經(jīng)常有香客問我拦止,道長,這世上最難降的妖魔是什么糜颠? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任汹族,我火速辦了婚禮,結(jié)果婚禮上其兴,老公的妹妹穿的比我還像新娘顶瞒。我一直安慰自己,他們只是感情好元旬,可當我...
    茶點故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布榴徐。 她就那樣靜靜地躺著,像睡著了一般匀归。 火紅的嫁衣襯著肌膚如雪坑资。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天穆端,我揣著相機與錄音袱贮,去河邊找鬼。 笑死体啰,一個胖子當著我的面吹牛攒巍,可吹牛的內(nèi)容都是我干的嗽仪。 我是一名探鬼主播,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼窑业,長吁一口氣:“原來是場噩夢啊……” “哼钦幔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起常柄,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤鲤氢,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后西潘,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體卷玉,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年喷市,在試婚紗的時候發(fā)現(xiàn)自己被綠了相种。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡品姓,死狀恐怖寝并,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情腹备,我是刑警寧澤衬潦,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站植酥,受9級特大地震影響镀岛,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜友驮,卻給世界環(huán)境...
    茶點故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一漂羊、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧卸留,春花似錦走越、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至匆赃,卻和暖如春淤毛,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背算柳。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工低淡, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓蔗蹋,卻偏偏與公主長得像何荚,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子猪杭,可洞房花燭夜當晚...
    茶點故事閱讀 43,465評論 2 348

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