el-table数据更新了,但是展示并没有更新

本文介绍了在Vue中遇到数据变更但视图未同步时,如何通过`this.$set`进行数据更新、使用`this.$forceUpdate()`强制更新视图以及通过创建新引用替换旧数据来解决视图刷新问题的方法。
摘要由CSDN通过智能技术生成

这是因为有时候vue无法监听到数据的变化,导致数据变化但是视图没有变化
解决办法:(可以从上往下一条一条进行尝试)
法一:使用this.$set进行数据的更新
法二:在数据更新完后执行this.$forceUpdate();进行强制更新
法三:更改引用,创建一个新的数组或对象,替换旧的数组或对象,这将强制 Vue 更新视图


 方法一:Vue.set(修改哪个对象或者数组,'键','值')

   this.AuditList.map((item, index2) => {
        if (index == index2) {
          this.$set(item, 'ModelSquare', true)
        }
      })

更改AuditList数组中,某个对象名是ModelSquare修改为true
// 是由于这个结果对的,视图不更新 this.AuditList[index].ModelSquare = true;

法二   

 this.$forceUpdate();

法三

// 对于数组
this.maf_version_list = [...this.maf_version_list];

// 对于对象
this.maf_empty_version = { ...this.maf_empty_version };

可以啦~

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值