前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >解决 Vue 动态生成 el-checkbox 点击无法赋值问题

解决 Vue 动态生成 el-checkbox 点击无法赋值问题

原创
作者头像
Krry
修改2019-03-01 17:29:56
5.8K0
修改2019-03-01 17:29:56
举报
文章被收录于专栏:KrryblogKrryblog

博客地址:https://ainyi.com/68

最近遇到一个问题,在一个页面需要动态渲染页面内的表单,其中包括 checkbox 表单类型,并且使用 Element 组件 UI 时,此时 v-model 绑定的数据也是动态生成的

例如:

定义的 data 的 form 里面是空对象,需要动态生成里面的 key

代码语言:txt
复制
export default {
  data() {
    return {
      form: {}
    }
  },
}

从后端接口得到 checkList,这个就是动态生成的表单数据

v-for 循环 checkList,得到 key,然后直接 v-model="form.key" 动态生成 form 里面的 key

代码语言:txt
复制
<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 的绑定数据类型是数组形式

那我在动态生成的时候,就它置为数组格式:

代码语言:txt
复制
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 方法解决这个==深入式响应原理==

代码语言:txt
复制
this.checkList.forEach(item => {
  let key = item.code
  this.$set(this.form, key, [])
})

完美解决~

博客地址:https://ainyi.com/68

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题来了
  • 解决
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档