vue3和2响应式对比

vue2中, 数据响应式通过getter和setter来对对象的读取和写入劫持
并且对于对象是递归进行绑定的, 因此可以进行深层次的绑定
但是对于数组, 是通过重写数组方法对数组内数据劫持

Object.defineProperty(obj, count, {
     get(){},
     set () {}
   })
console.log(obj.count)

vue3中, 数据响应不再是通过getter和setter劫持的, 而是通过h5的proxy数据代理
对象和数组都是如此, 数据不用再使用重写后的方法才能实现响应式, 可以直接操作数组
代理会返回一个代理对象

<script>
  let obj = {
    count: 1
  }
  const pro = new Proxy(obj, {
    /*
    代理内部需要结合Reflect反射对象来使用
    代理上对应的方法和反射的方法几乎都有对应, 代理可以结合反射来使用
    反射同样也会对数据劫持, 并且上面只有静态方法, 不能被创建实例
    */
    get (target, key) {
      console.log('读取了')
      return Reflect.get(target, key)
    },
    set (target, key, val) {
      console.log('写入了')
      Reflect.set(target, key, val)
    },
    deleteProperty (target, key) {
      console.log('删除了')
      Reflect.deleteProperty(target, key)
    }
  })
  // obj.count += 1 // 不能操作原对象, 只能操作代理对象
  pro.count += 1
  console.log(pro.count)
   delete obj.count // 直接操作原对象并不会走代理的方法
  console.log(obj, pro)
  delete pro.count // 操作代理对象, 会走代理里面设置的方法
</script>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值