您好,登錄后才能下訂單哦!
這篇文章主要介紹“Vue中對(duì)組件二開的方法是什么”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“Vue中對(duì)組件二開的方法是什么”文章能幫助大家解決問題。
在對(duì)antdv、element、自定義組件二開過程中,最困擾的問題如下:
組件那么多屬性我如何傳遞,props? v-model?屬性多的話透?jìng)饔悬c(diǎn)呆。
組件提供的多個(gè)事件怎么調(diào)用?emit? 事件多的情況下代碼冗余。
組件提供的方法怎么調(diào)用?ref 父子間并不能透?jìng)鳌5@個(gè)在react里很方便。
solt怎么處理,一個(gè)個(gè)自己定義透?jìng)鲉??作用域插槽、具名插槽很多的話怎么處理?/p>
這個(gè)是準(zhǔn)備去做二開UI組件的時(shí)候,遇到的幾個(gè)不能一下子就能打開思路的問題;
前兩個(gè)問題比較簡(jiǎn)單,利用$attts
和$listeners
兩個(gè)組件屬性就能解決。
a. $attts :
繼承所有的父組件屬性 (除了 prop 傳遞的屬性、class 和 style ) **,一般用在子組件的子元素上;
b $listeners:
它是一個(gè)對(duì)象,里面包含了作用在這個(gè)組件上的所有監(jiān)聽器,你就可以配合v-on="$listeners"
將所有的事件監(jiān)聽器指向這個(gè)組件的某個(gè)特定的子元素。(相當(dāng)于子組件繼承父組件的事件)
<templete> <div> <div>{{ text }}</div> <el-input v-bind="$attts" v-on="$listeners" placeholder="請(qǐng)輸入內(nèi)容"></el-input> </div> </templete> <script> export default { props:{ text:String, } mounted(){ console.log(this.$attrs) } } </script>
<templete> <div> <child type="text" v-model="input" text @blur="onBlur"></div> </div> </templete> <script> export default { data() { return { input: '', text:'子組件的props' } }, methods:{ onBlur(){ // ... } } } </script>
關(guān)于調(diào)用子組件中的方法(子組件拿不到父組件的ref),網(wǎng)上也看到了很多方案,從便捷度來(lái)說,我個(gè)人更傾向于將方法直接綁定在組件實(shí)例上。
tips:** 善用object中的entries**,返回Array<[key:string, value:any?]>類型的二維數(shù)組
<templete> <div> <child ref="childRef" type="text" v-model="input" text @blur="onBlur"></div> </div> </templete> <script> export default { data() { return { input: '', text:'子組件的props' } }, mounted(){ console.log(this.$ref.childRef) }, methods:{ onBlur(){ // ... } } } </script>
<templete> <div> <div>{{ text }}</div> <el-input ref="inpRef" v-bind="$attts" v-on="$listeners" placeholder="請(qǐng)輸入內(nèi)容"></el-input> </div> </templete> <script> export default { props:{ text:String, } mounted(){ console.log(this.$attrs) // 綁定ref到組件實(shí)例上 const entries = Object.entries(this.$ref.inpRef) for(const [key, value] of entries){ this[key] = value; } } </script>
插槽主要用的$slots,這邊對(duì)作用域插槽數(shù)據(jù)做了兜底,不然會(huì)報(bào)錯(cuò);
tips: 在vue模版中遍歷對(duì)象**,會(huì)拿到* value、name*
兩個(gè)值
<templete> <div> <child ref="childRef" type="text" v-model="input" text @blur="onBlur"> <template slot="prepend">Http://</template> </child> </div> </templete> <script> export default { data() { return { input: '', text:'子組件的props' } }, mounted(){ console.log(this.$ref.childRef) }, methods:{ onBlur(){ // ... } } } </script>
<templete> <div> <div>{{ text }}</div> <el-input ref="inpRef" v-bind="$attts" v-on="$listeners" placeholder="請(qǐng)輸入內(nèi)容"> <templete v-for="(value, name) in $slot" #[name]="slotData"> <slot :name="name" v-bind = "slotData || {}"></slot> </templete> </el-input> </div> </templete> <script> export default { props:{ text:String, } mounted(){ console.log(this.$attrs) // 綁定ref到組件示例上 const entries = Object.entries(this.$ref.inpRef) for(const [key, value] of entries){ this[key] = value; } } </script>
關(guān)于“Vue中對(duì)組件二開的方法是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。