博客地址:https://ainyi.com/68
最近遇到一個問題,在一個頁面需要動態渲染頁面內的表單,其中包括 checkbox 表單類型,並且使用 Element 組件 UI 時,此時 v-model 綁定的數據也是動態生成的
例如: 定義的 data 的 form 里面是空對象,需要動態生成里面的 key
export default {
data() {
return {
form: {}
}
},
}
從后端接口得到 checkList,這個就是動態生成的表單數據
v-for 循環 checkList,得到 key,然后直接 v-model="form.key" 動態生成 form 里面的 key
<el-form-item :label="item1.name+`:`" v-for="item1 in checkList" :key="item1.id">
<el-checkbox-group v-model="form[`${item1.code}`]">
<el-checkbox
:label="item2.id"
v-for="item2 in item1.values"
:key="item2.id">
{{ item2.value }}
</el-checkbox>
</el-checkbox-group>
</el-form-item>
問題來了
當頁面點擊動態生成的 CheckBox 方框,會出現全選的情況,查看 vue 數據,顯示如下:
正常的情況 CheckBox 的綁定數據類型是數組形式
那我在動態生成的時候,就它置為數組格式:
this.checkList.forEach(item => {
let key = item.code
this.form[key] = []
})
但還是沒用,會發現點擊任何 CheckBox 都無法勾選
解決
這是 vue 的深入響應式原理,官方說法和解決方法:
Vue 不允許在已經創建的實例上動態添加新的根級響應式屬性 (root-level reactive property) 然而它可以使用 Vue.set(object, key, value) 方法將響應屬性添加到嵌套的對象上
現在明白了,可以使用 Vue.set 方法解決這個深入式響應原理
this.checkList.forEach(item => {
let key = item.code
this.$set(this.form, key, [])
})
完美解決~
博客地址:https://ainyi.com/68