关注
Vue3更新重点

1、基于Proxy的观察者机制

Vue 2.x使用Object.defineProperty,参考文档https://www.jianshu.com/p/8fe1382ba135

Vue 3使用Proxy,对象代理,参考文档https://segmentfault.com/a/1190000010471230

Object.defineProperty的缺陷:

1)性能:通过遍历对象的属性进行监听,但是属性值也是对象就需要深度遍历。

2)无法监听数组:数组的主要操作场景是遍历,如果每一个元素都挂载set和get方法,会产生巨大性能消耗

3)对属性的添加、删除动作的检测;

4)对数组基于下标的修改、对于 .length修改的检测

所以之前数组的对象属性修改,需要手动set来通知页面修改了数据。如下截图


Proxy的优势:

1)可以直接监听对象而非属性,并返回一个新对象。

2)可以直接监听数组的变化

3)拦截方式多种多样,速度加倍,节省内存开销

2、完美支持tree-shaking

Tree-shaking是用来在打包编译成 bundle 时消除 ES6 Module 语法中未使用到的代码和模块。参考文档https://juejin.cn/post/6844903544756109319

Vue 2.x 的全局 API 比如 nextTick 无法被 TreeShake,所以就算你没有用到这些 API,它们还是会被打包到你的生产版本的代码包里

Vue 3中,官方团队重构了所有全局 API 的组织方式,让所有的 API 都支持了 TreeShaking

这样打包后的体积会更小

3、完美支持Typescript

Vue3源码使用ts编写

Typescript官方文档www.tslang.cn/

4、Composition API

实际例子,基于vue3开发的小demo,三角生成器

https://github.com/hellangel2017/triangle-generator


文章分类前端

评论

赞0

评论列表

微信小程序
QQ小程序

关于作者

点赞数:0
关注数:1
粉丝:1
文章:3
关注标签:0
加入于:2021-03-05