直接给一个数组项赋值,Vue 能检测到变化吗?

由于 JavaScript 的限制,Vue 不能检测到以下数组的变动:

当你利用索引直接设置一个数组项时,例如: vm.items[indexOfItem] = newValue
当你修改数组的长度时,例如: vm.items.length = newLength
为了解决第一个问题,Vue 提供了以下操作方法:
通过索引来修改数组,使其能成为响应式,解决直接使用赋值不能响应的问题

Vue.set(vm.data,2,'huanpu','name')    对数组
Vue.$set(vm.data,'K','V')  对对象
  1. 参数一表示要处理的数组名称。
  2. 参数二表示要处理的数组的索引。
  3. 参数三表示要处理的数组的值。
    为了解决第二个问题,Vue 提供了以下操作方法:
    // Array.prototype.splice
    vm.items.splice(newLength)
    newLength 就是指的你更新的长度

Vue.set()动态的新增与修改数据,触发视图更新
在这里插入图片描述
target:要更改的数据源(可以是对象或者数组)

key:要更改的具体数据(可以是字符串和数字)

value :重新赋的值

用法:向响应式对象中添加一个属性,并确保这个新属性同样是响应式的,且触发视图更新。

例:

data:{
     namelist:[
         {message:"叶落森",id:"1"},
         {message:"姜艳霞",id:"2"},
         {message:"姜小帅",id:"3"}
      ]
},
 Vue.set(this.namelist,1,{message:"yeluosen",id:"1"})

注:Vue.set()在methods中也可以写成this.$set()

Vue.set()不光能修改数据,还能添加数据

data:{
     items:[
         {message:"Test one",id:"1"},
         {message:"Test two",id:"2"},
         {message:"Test three",id:"3"}
      ]
},
var itemLen=this.items.length;
Vue.set(this.items,itemLen,{message:"Test add attr",id:itemLen});
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值