vue2.0数据更新,重新渲染视图的三种方法

问题:利用v-for渲染数据,通过方法改变了数据,视图没有更新。

原因:由于javascript的限制,Vue不能检测到以下变动的数组(如:objArr):

1.通过索引直接设置数组的某个值,this.objArr[index] = newValue;

2.通过索引直接设置数组中对象的某个属性,this.objArr[index].pro = newValue;

3.通过修改数组的长度,this.objArr.length = newLength;

解决重点:实现类似this.objArr[index] = newValue的效果,同时能更新视图

解决办法:

1.索引直接设置数组的某个值


  
  
  1. //1.Vue.set
  2. Vue.set( this.objArr,index,newValue) //(数组,索引,值)
  3. //2.prototype.splice
  4. this.objArr.splice(index, 1,newValue) //(索引,长度,值)
  5. //3.Object.assign
  6. this.objArr[index] = newValue
  7. this.objArr = Object.assign({}, this.objArr) //存在弊端,该objArr的类型会从数组变成对象

2.索引直接设置数组中对象的某个属性


  
  
  1. //1.Vue.set
  2. this.objArr[index].pro = newValue
  3. var tempObj = this.objArr[index]
  4. Vue.set( this.objArr,index,tempObj) //(数组,索引,值)
  5. //2.prototype.splice
  6. this.objArr[index].pro = newValue
  7. var tempObj = this.objArr[index]
  8. this.objArr.splice(index, 1,tempObj) //(索引,长度,值)
  9. //3.Object.assign
  10. this.objArr[index].pro = newValue
  11. this.objArr = Object.assign({}, this.objArr) //存在弊端,该objArr的类型会从数组变成对象

3.修改数组的长度


  
  
  1. //1.prototype.splice
  2. this.objArr.splice( this.objArr.length, 0, new Object()) //(索引,长度,值) 从长度索引开始增加一个新的对象。
  3. //2.Object.assign
  4. this.objArr.length = newLength
  5. this.objArr = Object.assign({}, this.objArr) //存在弊端,该objArr的类型会从数组变成对象

解决实例:

下载地址

推荐阅读:

事件捕获、事件冒泡详解

JS将数字转成货币形式的简单方法

原文:https://blog.csdn.net/a646070718/article/details/80147075

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值