vue2使用element中多选组件el-checkbox-group,数据与UI更新不同步

问题描述

使用element多选checkbox组件,点击勾选取消勾选,视图未变化,再次点击表单其他元素,多选组件勾选状态发生变化,视图和数据未同步

  • 第一次尝试:再el-checkbox-group多选父组件上增加点击事件,但是每次勾选并未触发,而是点表单其他元素之后才会触发当前事件。
  • 第二次尝试:使用vue. set
js 复制代码
this.$set(this.storeItem,   'array',  list)

这样修改后确实也起作用了。 
🍔 注意:这里使用 vue.set 起作用根本是,瞎猫碰上死耗子,不能响应的原因根本不是这个

这里我们根本没有添加 array属性,而只是去改变了array 属性的值,vue按理说应该是能够检测到的。
  • 最后解决方法:el-checkbox-group与el-check的数据同步有些问题
    给每个el-checkbox增加一个属性checked和一个事件change
js 复制代码
<el-checkbox-group v-model="dutyForm.hazardFactorsIds" >
  <el-checkbox
    v-for="item in hazardFactorsList"
    :key="item.ID"
    :label="item.ID"
    :checked="checked"
    @change="checked=!checked"
  >{{ item.Name }}</el-checkbox>
</el-checkbox-group>

--------js-数据层-----
 hazardFactorsList: [
  {
    ID: 'FK1',
    Name: '窒息(缺氧)'
  },
  {
    ID: 'FK2',
    Name: '中毒'
  },
  {
    ID: 'FK3',
    Name: '燃爆/爆炸'
  },
  {
    ID: 'FK4',
    Name: '机械伤害'
  },
  {
    ID: 'FK5',
    Name: '淹溺'
  }
],
checked: false // 这个 checked 没有任何作用,只是为了绕开elment 的这个坑
再每次修改<el-checkbox-group>的 v-model 的值的时候,先将 checked 设置为 false

vue2经常会出现视图和数据不同步的问题,尽量少使用vue.set方式,多操作状态的改变来影响视图

直接复制代码,可以看见视图和数据现在保持一致了

相关推荐
钢铁男儿1 分钟前
C#核心概念解析:析构函数、readonly与this关键字
开发语言·javascript·c#
saadiya~1 小时前
Vue3 + 高德地图实现围栏绘制与线路渲染(含 GeoJSON 支持)
vue.js
酷爱码1 小时前
CSS3实现的账号密码输入框提示效果
前端·javascript·css3
不爱吃饭爱吃菜1 小时前
uniapp小程序开发,判断跳转页面是否需要登录方法封装
开发语言·前端·javascript·vue.js·uni-app
菥菥爱嘻嘻1 小时前
React---day3
javascript·react.js·ecmascript
Dontla1 小时前
React声明式编程(手动控制,大型项目,深度定制)与Vue响应式系统(自动优化,中小型项目,快速开发)区别
javascript·vue.js·react.js
阳光开朗大男孩 = ̄ω ̄=2 小时前
【JavaScript】Ajax 侠客行:axios 轻功穿梭服务器间
前端·javascript·ajax
阮少年、3 小时前
Course 1: Best Practice of RK‘s start Maps SDK for javascript
开发语言·javascript·ecmascript
秋田君3 小时前
深入理解JavaScript设计模式之call,apply,this
javascript·设计模式
難釋懷3 小时前
Vue 实例生命周期
前端·javascript·vue.js