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


Posted in Javascript onFebruary 21, 2019

前言

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

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

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

完美解决~

总结

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

Javascript 相关文章推荐
javascript运行机制之this详细介绍
Feb 07 Javascript
js清空表单数据的两种方式(遍历+reset)
Jul 18 Javascript
jQuery实现的向下图文信息滚动效果
May 03 Javascript
详解JavaScript中shift()方法的使用
Jun 09 Javascript
高效Web开发的10个jQuery代码片段
Jul 22 Javascript
vue2 如何实现div contenteditable=“true”(类似于v-model)的效果
Feb 08 Javascript
Vue监听数据对象变化源码
Mar 09 Javascript
微信小程序 实现点击添加移除class
Jun 12 Javascript
JavaScript基于数组实现的栈与队列操作示例
Dec 22 Javascript
详解用vue2.x版本+adminLTE开源框架搭建后台应用模版
Mar 15 Javascript
Vue实现手机计算器
Aug 17 Javascript
js实现三角形粒子运动
Sep 22 Javascript
JavaScript数据结构与算法之基本排序算法定义与效率比较【冒泡、选择、插入排序】
Feb 21 #Javascript
JavaScript数据结构与算法之二叉树插入节点、生成二叉树示例
Feb 21 #Javascript
angularjs实现table表格td单元格单击变输入框/可编辑状态示例
Feb 21 #Javascript
Vue实现table上下移动功能示例
Feb 21 #Javascript
JavaScript数组、json对象、eval()函数用法实例分析
Feb 21 #Javascript
ES6基础之解构赋值(destructuring assignment)
Feb 21 #Javascript
ES6基础之展开语法(Spread syntax)
Feb 21 #Javascript
You might like
接收键盘指令的脚本
2006/06/26 Javascript
你真的了解JavaScript吗?
2007/02/24 Javascript
百度地图api应用标注地理位置信息(js版)
2013/02/01 Javascript
JavaScript中DOM详解
2015/04/13 Javascript
javascript实现点击后变换按钮显示文字的方法
2015/05/13 Javascript
bootstrap布局中input输入框右侧图标点击功能
2016/05/16 Javascript
利用node.js爬取指定排名网站的JS引用库详解
2017/07/25 Javascript
前端防止用户重复提交js实现代码示例
2018/09/07 Javascript
Vue组件之单向数据流的解决方法
2018/11/10 Javascript
NodeJS读取分析Nginx错误日志的方法
2019/05/14 NodeJs
Layui Form 自定义验证的实例代码
2019/09/14 Javascript
在微信小程序中使用mqtt服务的方法
2019/12/13 Javascript
jQuery实现的移动端图片缩放功能组件示例
2020/05/01 jQuery
js实现ajax的用户简单登入功能
2020/06/18 Javascript
Vue select 绑定动态变量的实例讲解
2020/10/22 Javascript
详解vite+ts快速搭建vue3项目以及介绍相关特性
2021/02/25 Vue.js
Python正则表达式匹配ip地址实例
2014/10/09 Python
Python使用MySQLdb for Python操作数据库教程
2014/10/11 Python
Python中Selenium模拟JQuery滑动解锁实例
2017/07/26 Python
Python多继承顺序实例分析
2018/05/26 Python
对python 多个分隔符split 的实例详解
2018/12/20 Python
详解python tkinter模块安装过程
2020/01/06 Python
浅谈keras中自定义二分类任务评价指标metrics的方法以及代码
2020/06/11 Python
pycharm激活方法到2099年(激活流程)
2020/09/22 Python
利用Python过滤相似文本的简单方法示例
2021/02/03 Python
Spartoo西班牙官网:法国时尚购物网站
2018/03/27 全球购物
马来西亚在线健康商店:Medipal Malaysia
2020/04/13 全球购物
为什么使用接口?
2014/08/13 面试题
护士自我介绍信
2014/01/13 职场文书
《绿色蝈蝈》教学反思
2014/03/02 职场文书
职业生涯规划书前言
2014/04/15 职场文书
捐款活动总结
2014/08/27 职场文书
名人演讲稿范文
2014/09/16 职场文书
团委工作总结2015
2015/04/02 职场文书
2015年护士长个人工作总结
2015/04/24 职场文书
运动会入场词
2015/07/18 职场文书