1、性能提升
响应式性能提升,由原来的
Object.defineProperty
改为基于ES6
的Proxy
,使其速度更快重写了
Vdom
(diff算法优化,增加静态标志)进行模板编译优化(静态提升,不参与更新的元素只被创建一次)
更加高效的组件初始化
2、更好的支持 typeScript
Vue.js 2.x
选用Flow
做类型检查,来避免一些因类型问题导致的错误,但是 Flow 对于一些复杂场景类型的检查,支持得并不好。Vue.js 3.0
抛弃了Flow
,使用TypeScript
重构了整个项目TypeScript
提供了更好的类型检查,能支持复杂的类型推断
3、新增 Composition API
Composition API
是 vue3
新增的功能,比 mixin
更强大。它可以把各个功能模块独立
开来,提高代码逻辑的可复用性,同时代码压缩性更强。
在 Vue3
中,定义 methods
、watch
、computed
、data
数据等都放在了 setup()
函数中。
1 | setup()`函数会在`created()`生命周期之前执行。执行顺序为:`beforeCreate > setup > created |
4、新增组件
Fragment
不再限制template
只有一个根节点。Teleport
传送门,允许我们将控制的内容传送到任意的DOM
中。Suspense
等待异步组件时渲染一些额外的内容,让应用有更好的用户体验。
5、Tree-shaking:支持摇树优化
摇树优化后会将不需要的模块修剪掉,真正需要的模块打到包内。优化后的项目体积只有原来的一半,加载速度更快。
6、Custom Renderer API: 自定义渲染器
实现 DOM 的方式进行 WebGL 编程。