博客地址:https://ainyi.com/68html
最近遇到一个问题,在一个页面须要动态渲染页面内的表单,其中包括 checkbox 表单类型,而且使用 Element 组件 UI 时,此时 v-model 绑定的数据也是动态生成的vue
例如:
定义的 data 的 form 里面是空对象,须要动态生成里面的 keyreact
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 数据,显示以下:
this
正常的状况 CheckBox 的绑定数据类型是数组形式code
那我在动态生成的时候,就它置为数组格式:orm
this.checkList.forEach(item => { let key = item.code this.form[key] = [] })
但仍是没用,会发现点击任何 CheckBox 都没法勾选htm
这是 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