vue 在监听里赋值不更新,或者是用下标给数组赋值不更新,解决方法

在Vue中遇到监听内对数组fileList的progress字段赋值不更新的问题。通过使用vm.$set实例方法来确保数组元素的赋值能够触发视图更新,避免数据同步延迟。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

请看一下代码,reader.onload是一个监听

reader.onload = function (e) {
              fileData.file=e.target.result;
              let config = {
                //添加上传进度监听事件
                onUploadProgress: e => {
                  var completeProgress = ((e.loaded / e.total * 100) | 0) + "%";
                  /*vm.fileList[vm.nowEditIndex].progress = completeProgress;*/
                  var newObj=vm.fileList[vm.nowEditIndex];
                  newObj.progress = completeProgress;
                  vm.$set(vm.fileList, vm.nowEditIndex, newObj);
                }
              };
              vm.$axios.post('/hgServices/bxzs/uploadAttachment.shtml',fileData,config).then(result => {
                if(result.data.success){
                  console.log(result.data);
                  var newObj=vm.fileList[vm.nowEditIndex];
                  newObj.id=result.data.data.id;
                  newObj.success=result.data.success;
                  vm.$set(vm.fileList, vm.nowEditIndex, newObj);
                }else{
                  vm.$alert(result.data.msg, '提示').then(() => {});
                }
              }).catch(function (error) {
                console.log(error);
                vm.$alert('服务异常[1003]', '提示').then(() => {});
              });
            }

当我们在给fileList这个Array里的progress字段赋值的时候以下方式赋值不会及时更新:

vm.fileList[vm.nowEditIndex].progress = completeProgress;

正确的方式应该这样赋值:

 var newObj=vm.fileList[vm.nowEditIndex];
 newObj.progress = completeProgress;
 vm.$set(vm.fileList, vm.nowEditIndex, newObj);

这里用到了 vm.$set 实例方法,该方法是全局方法 Vue.set 的一个别名!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Gavino.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值