Vue中對組件二開解決思路以及方案
一、背景
在對antdv、element、自定義組件二開過程中,最困擾的問題如下:??
- 組件那么多屬性我如何傳遞,props? v-model?屬性多的話透傳有點呆。
- 組件提供的多個事件怎么調(diào)用?emit? 事件多的情況下代碼冗余。
- 組件提供的方法怎么調(diào)用?ref 父子間并不能透傳。但這個在react里很方便。
- solt怎么處理,一個個自己定義透傳嗎?作用域插槽、具名插槽很多的話怎么處理?
這個是準(zhǔn)備去做二開UI組件的時候,遇到的幾個不能一下子就能打開思路的問題;
二、解決思路以及方案
前兩個問題比較簡單,利用$attts和$listeners兩個組件屬性就能解決。
a. $attts :繼承所有的父組件屬性 (除了 prop 傳遞的屬性、class 和 style ) **,一般用在子組件的子元素上;
b $listeners:它是一個對象,里面包含了作用在這個組件上的所有監(jiān)聽器,你就可以配合v-on="$listeners"將所有的事件監(jiān)聽器指向這個組件的某個特定的子元素。(相當(dāng)于子組件繼承父組件的事件)
<templete>
<div>
<div>{{ text }}</div>
<el-input v-bind="$attts" v-on="$listeners" placeholder="請輸入內(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)上也看到了很多方案,從便捷度來說,我個人更傾向于將方法直接綁定在組件實例上。
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="請輸入內(nèi)容"></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>
插槽主要用的$slots,這邊對作用域插槽數(shù)據(jù)做了兜底,不然會報錯;
tips: 在vue模版中遍歷對象**,會拿到* value、name*兩個值
<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="請輸入內(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中對組件二開解決思路以及方案的文章就介紹到這了,更多相關(guān)Vue組件二開內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談ElementUI el-select 數(shù)據(jù)過多解決辦法
下拉框的選項很多,上萬個選項甚至更多,這個時候如果全部把數(shù)據(jù)放到下拉框中渲染出來,瀏覽器會卡死,體驗會特別不好,本文主要介紹了ElementUI el-select 數(shù)據(jù)過多解決辦法,感興趣的可以了解一下2021-09-09
vue如何通過id從列表頁跳轉(zhuǎn)到對應(yīng)的詳情頁
這篇文章主要介紹了vue如何通過id從列表頁跳轉(zhuǎn)到對應(yīng)的詳情頁 ,需要的朋友可以參考下2018-05-05
解讀計算屬性和watch監(jiān)聽的區(qū)別及說明
計算屬性是基于它們的依賴進行緩存的,只有在它的相關(guān)依賴發(fā)生改變時才會重新求值,而watch則是一個更為通用的監(jiān)聽器,它可以在數(shù)據(jù)變化時執(zhí)行異步操作或開銷較大的操作2025-01-01

