直接给一个数组项赋值,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  就是指的你更新的长度

 

posted @ 2020-04-02 15:42  Mr_Riven  阅读(1518)  评论(0编辑  收藏  举报