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 中的replace方法说明
Apr 13 Javascript
jquery div拖动效果示例代码
Dec 08 Javascript
JavaScript原型链示例分享
Jan 26 Javascript
seajs中模块的解析规则详解和模块使用总结
Mar 12 Javascript
JavaScript中一个奇葩的IE浏览器判断方法
Apr 16 Javascript
深入理解JavaScript系列(33):设计模式之策略模式详解
Mar 03 Javascript
jQuery禁用键盘后退屏蔽F5刷新及禁用右键单击
Jan 22 Javascript
js+canvas绘制矩形的方法
Jan 28 Javascript
详解Vue 动态添加模板的几种方法
Apr 25 Javascript
详解Vue2 添加对scss的支持
Jan 02 Javascript
微信小程序MUI侧滑导航菜单示例(Popup弹出式,左侧不动,右侧滑动)
Jan 23 Javascript
Javascript执行上下文顺序的深入讲解
Nov 04 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
在PHP中运行Linux命令并启动SSH服务的例子
2014/06/12 PHP
php计算数组相同值出现次数的代码(array_count_values)
2015/01/20 PHP
smarty模板引擎从配置文件中获取数据的方法
2015/01/22 PHP
WordPress中登陆后关闭登陆页面及设置用户不可见栏目
2015/12/31 PHP
eclipse php wamp配置教程
2016/06/30 PHP
PHP多进程编程实例详解
2017/07/19 PHP
php 命名空间(namespace)原理与用法实例小结
2019/11/13 PHP
PHP实现新型冠状病毒疫情实时图的实例
2020/02/04 PHP
关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍
2020/07/13 PHP
理解JavaScript中的事件
2006/09/23 Javascript
DOM精简教程
2006/10/03 Javascript
jQuery 1.3 和 Validation 验证插件1.5.1
2009/07/09 Javascript
数组Array进行原型prototype扩展后带来的for in遍历问题
2010/02/07 Javascript
JS获取屏幕,浏览器窗口大小,网页高度宽度(实现代码)
2013/12/17 Javascript
JS判断变量是否为空判断是否null
2014/07/25 Javascript
使用Chrome浏览器调试AngularJS应用的方法
2015/06/18 Javascript
Angularjs实现mvvm式的选项卡示例代码
2016/09/08 Javascript
js获取ip和地区
2017/03/10 Javascript
从vue基础开始创建一个简单的增删改查的实例代码(推荐)
2018/02/11 Javascript
在vue里使用codemirror遇到的问题
2018/11/01 Javascript
Vue  webpack 项目自动打包压缩成zip文件的方法
2019/07/24 Javascript
jQuery HTML设置内容和属性操作实例分析
2020/05/20 jQuery
[01:46]2020完美世界全国高校联赛秋季赛报名开启
2020/10/15 DOTA
淘宝秒杀python脚本 扫码登录版
2019/09/19 Python
在服务器上安装python3.8.2环境的教程详解
2020/04/26 Python
Spark处理数据排序问题如何避免OOM
2020/05/21 Python
python与c语言的语法有哪些不一样的
2020/09/13 Python
HTML5中如何显示视频呢 HTML5视频播放demo
2013/06/08 HTML / CSS
复古斯堪的纳维亚儿童服装:Baby go Retro
2017/09/09 全球购物
输入N,打印N*N矩阵
2012/02/20 面试题
什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?
2016/08/13 面试题
法学专业个人求职信
2013/09/26 职场文书
班级读书活动总结
2014/06/30 职场文书
春季运动会开幕词
2015/01/28 职场文书
详解在SQLPlus中实现上下键翻查历史命令的功能
2022/03/18 SQL Server
JavaScript实现一键复制内容剪贴板
2022/07/23 Javascript