vue2.x中$attrs的使用方法教程
最近筆者在做大屏項(xiàng)目的時(shí)候,由于組件數(shù)據(jù)傳遞,一層傳遞一層,使用vuex
或者pinia
又顯得過于笨重。故而想起了那個(gè)傳說中的v-bind="$attrs"
以及v-on="$listeners"
,下面就來聊下使用:
上圖組件之間的關(guān)系如下:
ComponentGrandParent
為最外層父級(jí)組件(爺)ComponentParent
為中間層父級(jí)組件(父)ComponentChild
為子組件
ComponentGrandParent
組件想把props
傳遞給ComponentChild
就通常需要在ComponentParent
中通過屬性一個(gè)個(gè)的傳遞
//ComponentParent組件 <template> <ComponentChild :propa="prop1" :propb="prop2" :propc="prop3" ... /> </template>
如果需要傳遞的屬性多,而且ComponentParent
中沒有用到的ComponentGrandParent
傳遞過來的屬性的時(shí)候,就很尷尬,很不優(yōu)雅,有時(shí)候還需要在寫watch
監(jiān)聽傳遞過來的數(shù)據(jù),然后再賦值給data
中的prop1
,然后再傳遞給ComponentChild
使用$attrs
能解決上述問題,那么什么是$attrs
呢?
透?jìng)?Attributes 是指由父組件傳入,且沒有被子組件聲明為props
或是組件自定義事件的 attributes
和事件處理函數(shù)。默認(rèn)情況下,若是單一根節(jié)點(diǎn)組件,$attrs
中的所有屬性都是直接自動(dòng)繼承自組件的根元素。
大白話講就是沒有父組件傳遞過來的props
,在子組件中沒有對(duì)應(yīng)的props
聲明,那么在子組件中就可以通過v-on:$attrs
將父組件的props
透?jìng)?/strong>給孫組件,在二次封裝一些elementui
的組件有奇效
紙上得來終覺淺,下面來看下實(shí)際的使用,目錄結(jié)構(gòu)如下:
src
├─ blocks
│ └─ PassVal
│ ├─ components
│ │ └─ PassInput.vue
│ └─ PassVal.vue
├─ view
│ ├─ basic
│ │ └─ BasicView.vue
├─ App.vue
└─ main.js
BasicView.vue(父組件)
中引入PassVal.vue(子組件)
;PassVal.vue(子組件)
中引入PassInput.vue(孫組件)
//BasicView.vue代碼如下: <template> <div class="basic"> <h3><i class="title_icon"></i>基礎(chǔ)知識(shí)</h3> <PassVal placeholder="我是placerholder" :clearable="true" :defaultVal="defaultVal" @changGrandChildVal="changGrandChildVal" /> </div> </template> <script> import PassVal from "@/blocks/PassVal/PassVal.vue"; export default { data() { return { defaultVal: "測(cè)試透?jìng)?, }; }, components: { PassVal, }, methods: { /** * @function input值修改回調(diào)函數(shù) */ changGrandChildVal(val) { console.log("PassInput組件的值變了", val); }, }, }; </script> <style scoped> .basic { width: 100%; height: 100%; } </style>
- 在
PassVal
想要傳遞三個(gè)屬性placeholder="我是placerholder"
、:clearable="true"
以及:defaultVal="defaultVal"
接著來看下在PassVal
中的處理:
//PassVal.vue <template> <div class="passval"> <el-divider content-position="left">1-$attr和 $listeners</el-divider> <div class="container"> <div class="flex-two"> <passInput v-bind="$attrs" v-on="$listeners"></passInput> </div> </div> </div> </template> <script> import PassInput from "./components/PassInput.vue"; export default { components: { PassInput, }, props: { defaultVal: { type: String, default: "輸入框默認(rèn)值", }, }, }; </script> <style scoped> .passval { width: 100%; height: 100%; } </style>
- 這里通過
v-bind="$attrs"
和v-on="$listeners"
將屬性和方法透?jìng)飨氯?/li> - 如果在
PassVal.vue
中有關(guān)于來自父組件BasicView.vue
相關(guān)的props
聲明,那么v-bind="$attrs"
透?jìng)鞯膶傩詴?huì)將聲明的這個(gè)屬性剔除,透?jìng)饔嘞碌?code>porps屬性。- 例如:如果在
PassVal.vue
中的props
中聲明defaultVal
,那么父組件BasicView.vue
傳遞過來的defaultVal
將無法通過v-bind="$attrs"
透?jìng)鹘o子組件PassInput.vue
- 例如:如果在
而在PassInput.vue
組件中
<template> <div class="pass-input"> <el-input v-bind="$attrs" v-model="value" @input="inputHandler"></el-input> </div> </template> <script> export default { name: "PassInput", created() { console.log("我是$attrs", this.$attrs); console.log("我是$listeners", this.$listeners); }, data() { return { value: "", }; }, methods: { /** * @function el-input的輸入回調(diào)函數(shù) */ inputHandler(val) { this.$emit("changGrandChildVal", val); }, }, }; </script> <style scoped> .pass-input { width: 100%; height: 100%; } </style>
從而實(shí)現(xiàn)了優(yōu)雅的屬性透?jìng)?,在組件封裝中比較有用。
生命周期中的console.log("我是$attrs", this.$attrs)和console.log("我是$listeners", this.$listeners);
以結(jié)果如下:
總結(jié)
到此這篇關(guān)于vue2.x中$attrs使用的文章就介紹到這了,更多相關(guān)vue2.x $attrs使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實(shí)現(xiàn)滾動(dòng)底部加載下一頁指令的示例代碼
vue中監(jiān)控滾動(dòng)事件可以直接在mounted中綁定滾動(dòng)事件,然后在銷毀前解綁滾動(dòng)事件,本文通過實(shí)例代碼介紹vue實(shí)現(xiàn)滾動(dòng)底部加載下一頁指令的過程,感興趣的朋友跟隨小編一起看看吧2023-10-10使用kbone解決Vue項(xiàng)目同時(shí)支持小程序問題
這篇文章主要介紹了使用kbone解決Vue項(xiàng)目同時(shí)支持小程序問題,本文通過一個(gè)todo的例子跟大家詳細(xì)介紹,需要的朋友可以參考下2019-11-11vue實(shí)現(xiàn)純前端表格滾動(dòng)分頁加載
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)純前端表格滾動(dòng)分頁加載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04對(duì)類Vue的MVVM前端庫的實(shí)現(xiàn)代碼
這篇文章主要介紹了對(duì)類Vue的MVVM前端庫的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09為Vue3?組件標(biāo)注?TS?類型實(shí)例詳解
這篇文章主要為大家介紹了為Vue3?組件標(biāo)注?TS?類型實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08vue+vux?vux安裝出現(xiàn)錯(cuò)誤問題及解決
這篇文章主要介紹了vue+vux?vux安裝出現(xiàn)錯(cuò)誤問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08vue項(xiàng)目中輪詢狀態(tài)更改方式(鉤子函數(shù))
這篇文章主要介紹了vue項(xiàng)目中輪詢狀態(tài)更改方式(鉤子函數(shù)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10