100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > vue 给checkbox 赋值_Vue动态生成el-checkbox点击无法赋值的解决方法

vue 给checkbox 赋值_Vue动态生成el-checkbox点击无法赋值的解决方法

时间:2023-05-04 19:33:36

相关推荐

vue 给checkbox 赋值_Vue动态生成el-checkbox点击无法赋值的解决方法

前言

最近遇到一个问题,在一个页面需要动态渲染页面内的表单,其中包括 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 数据,显示如下:

绑定的数据居然是 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, [])

})

完美解决~

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

本文标题: Vue动态生成el-checkbox点击无法赋值的解决方法

本文地址: /wangluo/javascript/252936.html

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。