vue3 新增的亮点
- Performance 性能优化
- Tree-shaking 支持摇树优化
- Composition API 组合式API
- 新增组件 Fragment Teleport Supense
- 更好的支持ts
- Custom render API 自定义渲染器
性能提升
- 响应式性能提升
1.1 diff 方法优化
在vue2中,数据发生变化时,会生成一个新的dom树,然后和之前的dom树进行比较,找到变更的节点然后更新到真实的dom上。在比较的过程中会对没有发生改变的dom也进行比较,这样消耗了一定的时间。
在vue3中,在创建虚拟dom时会根据dom的内容添加一个静态标记,在数据发生变化时就会带着静态标记的节点去对比,能够快速找到需要更新的dom。
1.2 事件侦听器缓存
vue2中 onClick 被认为是动态绑定,每次都会最终它的变化。但因为是同一个函数,vue3中进行了缓存。
1.3 ssr渲染
当存在大量静态内容时,这些内容会被当做纯字符串推进一个 buffer 内,即使存在动态绑定,也会通过模板插值潜入进去,这样会比虚拟 DOM 渲染快得多。 - 代码体积
vue3 移除了一些不常用的 API,如:inline-template、filter 等,使用 tree-shaking。
Tree Shaking 摇树优化,指的就是当我们引入一个模块的时候,不引入这个模块的所有代码,只引入我们需要的代码。
在 vue2 中,很多函数都挂载到全局 Vue 对象上,如:nextTick、set 函数等,虽然我们不常用,但打包时只要引入 Vue 这些全局函数会打包进 bundle 中。而 vue3 中,引入tree-shaking,所有的 API 都通过 ES6 模块化的方式引入,这样就能够让 webpack 或 rollup 等打包工具在打包时,就会自动对没有用到的 API 进行剔除,最小化 bundle 体积。 - 编译优化
3.1 静态提升
在vue2中,dom更新时无论元素是否需要参与更新,都会重新创建再渲染。vue3使用了静态提升后,对于不参与更新的元素只会创建一次,在渲染的过程直接复用。
3.2 Fragment
模板内不用再创建一个唯一根节点,可以直接放同级标签和内容。就相当于少了一个节点嵌套渲染。
选项式 api VS 组合式 api
在 vue2 中采用选项式 api ,会在 vue 文件的 data、methods、watch、computed 中定义属性和方法,共同处理页面逻辑,多个功能相互交叉,缠绕在一起,代码过于分散。
而 vue3 新增了组合式 api ,一个功能模块代码会集中到一起,实现高内聚,低耦合。提高代码的可读性和可维护性,基于函数组合的 api 更好地重用逻辑代码
proxy 相对 Object.defineProperty 优点有哪些?
vue2 利用 Object.defineProperty 来劫持 data 数据的 getter 和 setter 操作,使得 data 在被访问或赋值时,动态更新绑定的 template 模板。而 Object.defineProperty 必须遍历所有的预值才能劫持每一个属性,这一缺点正好能够被 proxy 解决。
proxy 相比 Object.defineProperty 优点分别为:
代码的执行效果更快。
proxy 可以直接监听对象而不是它的属性。
proxy 可以直接监听数组的每个元素的变化。
proxy 不需要初始化的时候遍历所有属性,如果有多层嵌套的话,只访问某个属性的时候,proxy 能够快速访问到,而 Object.defineProperty 还需要遍历所有属性,然后逐级向下访问。
proxy 返回的是一个新对象,可以直接操作新对象而达到目标。而 Object.defineProperty 操作的是原对象,只能遍历对象属性然后对其直接修改。
proxy 有 13 种拦截方法,不限于 apply、ownKeys、deleteProperty 等,而 Object.defineporperty 不具备。
在 vue2 中,我们给对象新增一个属性时,如果新增属性的值发生改变的时候,我们发现视图并没有更新,因为新增属性是无法监听到的。同样的,通过下标直接改变数组,视图也是无法更新的,也是因为监听不到。在 vue3 中新增 proxy ,解决了这些问题。
更好的 ts 支持
vue2 不适合使用 ts,在于它的 Options API 风格。
options 是一个简单的对象,而 ts 是一种类型系统、面向对象的语法,两个不匹配。
vue3 新增了 defineComponent 函数,使组件在 ts 下,更好的利用参数类型推断。如:reactive 和 ref 很具有代表性。
更先进的组件
- Fragment
在 vue2 中,每个模板必须有一个根节点,否则就会报错。
vue3 中可以不需要根节点,多个元素或标签可并列存在。 - Teleport
可以把 teleport 中的内容添加到任意的节点内,对于嵌套较深的组件来说绝对是一个福音。 - Supense
允许程序在等待异步组件渲染一些后备的内容,可以让我们创建一个平滑的用户体验。