【三十天精通Vue 3】第十六天 Vue 3 的虚拟 DOM 原理详解

1,503 阅读2分钟

请添加图片描述

原文地址:chenshuyu.blog.csdn.net/article/det…

引言

Vue 3 的虚拟 DOM 是一种用于优化 Vue 应用程序性能的技术。它通过将组件实例转换为虚拟 DOM,并在组件更新时递归地更新虚拟 DOM,以达到高效的渲染性能。在 Vue 3 中,虚拟 DOM 树由 VNode 组成,VNode 是虚拟 DOM 的基本单元。VNode 具有自己的类型和结构,并且可以通过补丁算法进行更新。

一、Vue 3 的虚拟 DOM 树结构

3.1.2 模板编译器的性能优化

为了提高模板编译器的性能,Vue 3 引入了以下几种优化方式:

  1. 缓存编译结果:将编译后的渲染函数缓存起来,下次渲染时直接使用缓存的渲染函数。
  2. 静态提升:将静态节点提升为常量,在渲染时只需要创建一次静态节点。
  3. 静态节点提取:将静态节点提取到单独的 VNode 中,避免每次重新渲染时都重新创建静态节点。
  4. 模板 inlining:将小型的模板内联到父级模板中,减少了模板编译器的工作量。

3.2 Vue 3 的渲染流程

原文地址:chenshuyu.blog.csdn.net/article/det…

3.2.1 Vue 3 的初始化流程

使用 Keep-Alive 缓存组件可以避免频繁的组件销毁和创建,从而提高页面的性能。以下是一些使用 Keep-Alive 的方法:

  1. 在组件外层包裹一个 Keep-Alive 组件:这样包裹的组件会被缓存起来,当下次需要渲染时,就会直接使用缓存中的组件,而不是重新创建。
  2. 在需要缓存的组件上添加一个 name 属性:这样 Vue 3 才能正确地缓存该组件。
  3. 在需要销毁缓存的组件时,使用 $destroy 方法:这样可以手动销毁缓存的组件,从而释放内存。

在这里插入图片描述