【Vue | 补洞 | 22】Vue2 监测数据原理(数组)

上文提到 Object.defineProperty 无法监测数组变化,那么 Vue 是如何解决该问题?


1. 原理

Vue2监测数据变化原理 这篇文章可知,Object.defineProperty 有两个缺陷:

  • 无法监测对象属性的新增和删除
  • 无法监测数组数据变化

2. 示例代码

  也就是说,直接通过索引值修改数组的数据,Vue 无法监测到数组的变化,因为没有对应的 set 和 get 方法。如下:

<template>
  <div>
    <li v-for="(item, index) of list" :key="index">{{ item }}</li>
    <button @click="changeList">通过索引修改数组值</button>
  </div>
</template>

<script>
    export default {
     	data() {
          return {
            list: [0, 1, 2, 3]
          } 
        },
        methods: {
          change() {
            // 通过索引直接修改数组值的,无法被更新到视图上
            this.list[0] = 5
          }
        }   
    }
</script>

在这里插入图片描述


3. 解决方法

1)方法一:使用 Vue.set API(在组件中,使用 this.$set)进行修改

this.$set(要修改的数组,要修改的索引值,改变后的值)

change() {
   this.$set(this.list, 0, 改变后的值)
}

2)方法二:Vue 对数组常见的 7个操作方法进行了重新包装,保证在数组操作前能监听到数组变化。包括以下七种:

  • push:从数组尾部插入
  • pop:从数组尾部移除
  • unshift:从数组头部插入
  • shift:从数组头部移除
  • splice:替换
  • sort:排序
  • reverse:颠倒顺序

将第2点中的示例代码,改造成如下(方法1或方法2任选一种):

// 方法1
change() {
   this.$set(this.list, 0, '改变后的值')
}

// 方法2
change() {
   // 能监听到 hobby 的变化
   this.list.splice(0, 1, '改变后的值')
}

在这里插入图片描述

4. 总结

  • Vue2 中,Object.defineProperty 无法监测数组的变化
  • 因此,Vue2 对7个常见的数组操作方法进行了包装,通过这7种方法操作的数组,都可以被 Vue 监测到
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值