时间:2021-05-26
前言
最近遇到一个问题,在一个页面需要动态渲染页面内的表单,其中包括 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 数据,显示如下:
绑定的数据居然是 Boolean 类型,怪不得会出现要么全部勾选,要不全部不选
正常的情况 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, [])})完美解决~
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
遇到jquery无法为动态生成的元素添加点击事件,谷歌一下,整理一下解决方法如下:(中间的元素是动态生成的),现在想为添加点击事件,例子如下:这是元素内容//i
android的listview,当item里面有可点击的元素,比如说checkbox,焦点就会给了checkbox,点击item就无效了。解决方法是在item
一vue方法实现Vue方法与事件点击我varmyVue=newVue({el:'#test',methods:{//这里使用methodssayHi:funct
动态变量名赋值在使用tkinter时需要动态生成变量,如动态生成var1...var10变量。使用exec动态赋值exec在python3中是内置函数,它支持p
别人看不到我的qq动态是因为QQ空间设置了仅自己可见,所以别人无法看到;QQ空间加密以后别人也是无法看到的。解决方法如下: 1、登录手机qq; 2、点击左上