最近遇到一个问题,在一个页面需要动态渲染页面内的表单,其中包括 checkbox 表单类型,并且使用 Element 组件 UI 时,此时 v-model 绑定的数据也是动态生成的
例如:
定义的 data 的 form 里面是空对象,需要动态生成里面的 key
export default {
data() {
return {
form: {}
}
},
}
从后端接口得到 checkList,这个就是动态生成的表单数据
v-for 循环 checkList,得到 key,然后直接 v-model="form.key" 动态生成 form 里面的 key
:label="item2.id"
v-for="item2 in item1.values"
:key="item2.id">
{ { item2.value }}
问题来了
当页面点击动态生成的 CheckBox 方框,会出现全选的情况,查看 vue 数据,显示如下:

正常的情况 CheckBox 的绑定数据类型是数组形式
那我在动态生

本文介绍了在Vue中使用Element UI组件库时,动态生成checkbox表单并绑定v-model时遇到的问题。当数据是动态生成的,直接使用v-model="form.key"会导致全选情况,原因是违反了Vue的深入响应式原则。解决方法是利用Vue.set方法,如`this.$set(this.form, key, [])`,确保动态添加的属性成为响应式的。"
139552377,17663336,华为OD面试题解析:最小异或问题,"['华为OD', '面试题', '编程题', 'Java', '算法']
最低0.47元/天 解锁文章
2479

被折叠的 条评论
为什么被折叠?



