vue数据改变页面不会及时更新

本文探讨了在Vue中遇到的数据变化不更新的问题。当watch监听未生效时,可以通过this.$forceUpdate()强制渲染解决。同时,对于数组的变动,需使用splice(), push()等方法或this.$set()确保监听触发。this.$set()方法能确保对象和数组的赋值更新并触发视图刷新,正确使用可以避免数据变化不更新的困扰。
摘要由CSDN通过智能技术生成

1.watch监听到数据的变化但页面没有刷新

在数据改动的代码后加 this.$forceUpdate();

添加this.$forceUpdate();进行强制渲染,效果实现。因为数据层次太多,render函数没有自动更新,需手动强制刷新。

2.没有监听到数据的变化

例如:改变了数组中的某一项或者改变了对象中的某个元素时,监听则未生效。

数组若要触发监听,下面方法即可触发

如:splice(),push() 等js方法

当然了,也可以使用vue中的方法 this.$set(object, index, new)

this.$set()方法是vue自带的可对数组和对象进行赋值,并触发监听的方法。

第一个参数为你要改变的数组或对象

第二个参数为下标,或者元素名称

第三个参数为新值

例:

this.$set(
      _this.answerList[index],//对象或数组
      'imageUrlString',//对象的某个属性
       result,
);
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值