1、基于Proxy的观察者机制

Vue 2.x使用Object.defineProperty,参考文档www.jianshu.com/p/8fe1382ba…

Vue 3使用Proxy,对象代理

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

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

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

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

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

Vue3更新重点_前端开发

Proxy的优势:

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

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

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

2、完美支持tree-shaking

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

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,三角生成器

github.com/hellangel20…

Vue3更新重点_前端开发_02