Vue3升级内容

Vue3升级内容
全部用ts重写 (响应式, vdom, 模板编译等)
性能提升, 代码量减少
调整部分api

Proxy实现响应式

回顾2.0的defineProperty

  1. 通过defineProperty实现一个对象的get和set, set上实现深度监听(分别在初始化函数的时候和set的时候. 深度监听就是一个递归), 但是在递归的时候是一次性递归的, 因此会导致层级比较深时, 性能不好. 监听数组的时候重写
  2. 删除属性, 新增属性的时候, 监听不到

Object.defineProperty的不足

  1. 深度监听需要一次性递归, 如果data数据层级较深, 会卡顿
  2. 无法监听新增/删除属性 (需要用Vue.set和Vue.delete )
  3. 无法原生监听数组, 需要特殊处理

Reflect作用

  1. 和Proxy能力一一对应
  2. 规范化, 标准化, 函数式
  3. 替代掉Object上的工具函数

Proxy实现响应式

  1. 深度监听, 性能更好
  2. 可监听 新增/删除 属性
  3. 监听数组变化
  4. 无法兼容所有浏览器, 无法polyfill
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值