vue2和vue3的渲染过程简述版

news2024/11/26 0:40:58

在这里插入图片描述

文章目录

  • vue2渲染过程
  • vue3渲染过程
      • 优化和扩充
  • vue2和vue3对比


vue2渲染过程

在Vue 2的渲染过程中,包括以下几个关键步骤:

  1. 解析模板:Vue 2使用基于HTML语法的模板,首先会将模板解析成抽象语法树(AST),用于后续的编译和渲染过程。

  2. 编译模板:将解析后的抽象语法树编译成渲染函数。编译过程包括静态标记、生成可复用的渲染函数以及处理动态绑定等操作。

  • 静态标记阶段通过遍历抽象语法树,给其中的静态节点打上标记,这些节点在重新渲染时可以被跳过,从而提升渲染性能。
  • 生成可复用的渲染函数阶段会将剩余的动态节点转换成JavaScript的渲染函数,这些函数接收数据作为入参,返回虚拟DOM(Virtual DOM)。
  • 处理动态绑定阶段会将具有动态绑定的节点与对应的响应式数据建立关联,当数据发生变化时,会触发重新渲染的过程。
  1. 创建实例:通过Vue构造函数创建组件实例,并初始化相关属性和事件。

  2. 数据响应式:Vue使用双向绑定机制,在数据发生变化时自动更新对应的视图。在渲染过程中,Vue会为每个响应式数据对象设置侦听器,当数据发生改变时,会触发重新渲染的过程。

  3. 渲染虚拟DOM:Vue根据渲染函数生成虚拟DOM(Virtual DOM),虚拟DOM是一种轻量级的JavaScript对象,用于表示真实的DOM结构。

Diff算法会逐层比较新旧虚拟DOM树的节点,找出需要更新的节点。
使用key来唯一标识节点,可以帮助Diff算法更准确地找出差异。

  1. Diff算法:在重新渲染之前,Vue会进行虚拟DOM的比对,通过Diff算法找出需要更新的部分。Diff算法会高效地找出差异,并最小化DOM操作,提高渲染性能。

  2. 应用更新:根据Diff算法的结果,Vue将只更新需要修改的部分DOM节点,而不是重新渲染整个视图。这样可以减少不必要的计算和DOM操作,提高性能。

  3. 更新后钩子:在完成DOM更新后,Vue会触发相应的生命周期钩子函数,如updated,供开发者进行后续操作或处理副作用。

以上是Vue 2的简要渲染过程,通过将模板解析成渲染函数、创建实例、生成虚拟DOM以及更新差异等步骤,Vue能够高效地实现数据驱动的视图更新。

vue3渲染过程

在Vue 3中,渲染过程主要包括以下几个步骤:

  1. 解析模板:Vue 3使用编译器将模板解析成渲染函数,这是在构建阶段完成的。渲染函数可以理解为一个JavaScript函数,用于生成虚拟DOM。

  2. 创建响应式数据:Vue 3使用reactive()函数对数据进行响应式处理。该函数会将数据转换成响应式对象,使得当数据发生变化时,能够触发视图的重新渲染。

  3. 初始化组件实例:在创建组件实例时,Vue 3会执行一系列初始化操作,包括设置组件的初始状态、注入依赖项等。

  4. 渲染虚拟DOM:调用渲染函数生成虚拟DOM(VNode)。虚拟DOM是一个轻量级的JavaScript对象,它描述了要渲染到页面上的元素及其属性。

  5. 比较与更新:Vue 3通过算法优化,将新旧虚拟DOM进行比较,找出两者之间的差异。这个过程称为虚拟DOM diff。然后,根据差异进行有针对性地更新。

  6. 生成真实DOM:根据最新的虚拟DOM,Vue 3会进行真实DOM的创建或更新。

  7. 将真实DOM插入页面:在更新完真实DOM后,Vue 3将其插入到页面中,用户最终看到的就是这个经过更新的页面。

  8. 监听数据变化:在组件实例被挂载到页面上后,Vue 3会自动建立数据的观察者机制,当数据发生变化时,会通知相关依赖进行重新渲染。

优化和扩充

在Vue 3的渲染过程中,除了上述提到的步骤,还有一些优化和扩充的内容:

  1. 编译优化:Vue 3使用了静态模板提升(Static Template Hoisting)的技术,将静态节点转换成常量,在渲染过程中减少不必要的计算。这样可以降低虚拟DOM的生成和比对过程的开销,提高性能。

  2. 标记优化:Vue 3引入了递增式的静态标记(Incremental Static Marking),通过分层次、增量式的标记方式,将模板标记为可静态节点、需要动态跟踪的节点以及可能产生动态内容的节点,进一步减少不必要的更新操作。

  3. 静态提升:Vue 3可以将静态节点进行提升,从而避免重复创建和比对。这意味着在重新渲染时,Vue 3可以直接复用之前生成的静态节点,而无需重新生成和比对。

  4. Fragments:Vue 3支持Fragments(片段),可以在组件内部渲染多个根级别的元素,而无需包裹额外的父级元素。这样可以更灵活地组织组件的结构。

  5. Suspense:Vue 3引入了Suspense机制,用于处理异步组件的渲染。通过Suspense可以在异步组件加载中显示自定义的等待界面,提升用户体验。

  6. Teleport:Vue 3提供了Teleport(传送门)功能,可以将组件的内容渲染到DOM结构的其他位置,而不受组件嵌套层次的限制。这在处理模态框、弹出菜单等场景下非常有用。

Vue 3在渲染过程中进行了多方面的优化,包括编译优化、标记优化、静态提升等,以提升整体性能。此外,还引入了一些新特性如Fragments、Suspense和Teleport,为开发者提供了更加灵活和便利的渲染方式。

vue2和vue3对比

Vue 3通过使用静态模板提升、编译时优化等技术手段,使得整个渲染过程更为高效,并且相较于Vue 2有更好的性能表现。同时,Vue 3还引入了递增式的静态标记,可以进一步减少不必要的更新操作,提升渲染性能。

Vue 3的渲染过程包括解析模板、创建响应式数据、初始化组件实例、渲染虚拟DOM、比较与更新、生成真实DOM、将真实DOM插入页面和监听数据变化等环节。通过对比新旧虚拟DOM的差异,Vue 3能够高效地更新页面,并提供响应式的数据绑定。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/662854.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

高频前端面试题汇总之代码输出结果篇

前言: 代码输出结果是面试中常考的题目,一段代码中可能涉及到很多的知识点,这就考察到了应聘者的基础能力。在前端面试中,常考的代码输出问题主要涉及到以下知识点:异步编程、事件循环、this指向、作用域、变量提升、…

SolidWorks软件三维建模教程——莫比乌斯环建模案例

SolidWorks是达索系统(Dassault Systemes )下的子公司,专门负责研发与销售机械设计软件的视窗产品。SOLIDWORKS软件三维建模功能强大,为制造型企业提供SOLIDWORKS一体化解决方案和服务。 今天微辰三维就以莫比乌斯环的三维建模案例…

智慧灯杆云盒是什么?如何挑选智慧云盒?

慧路灯杆云盒,是一种专门用于智慧路灯杆远距通信、远程控制、数据分析、边缘计算的智能终端设备,智慧路灯杆云盒作为联通智慧路灯杆与物联网云平台的桥梁,可以有效提高智慧路灯杆的管理效率、降低维护成本、实现多样化设备联动协同功能&#…

【C++】的多态

目录 1. 多态的概念2. 多态的定义及实现虚函数虚函数的重写虚函数重写的两个例外:C11 override 和 final重载、覆盖(重写)、隐藏(重定义)的对比 3. 抽象类接口继承和实现继承 4. 多态的原理虚函数表 5. 单继承和多继承关系中的虚函数表单继承中的虚函数表多继承中的…

qemu虚拟机配置网络

一、实现qemu虚机&宿主机网络互通 qemu虚机的网络介绍及原理可参考前人文章:Linux 内核调试 七:qemu网络配置_lqonlylove的博客-CSDN博客 这里只简单梳理下操作流程,以便快速实现网络互通。 1.宿主机创建 tap0 [rootlocalhost ~]# if…

一文入门Mongodb

目录 概述核心概念下载与安装版本问题环境配置cmd运行 数据库与集合命令数据库命令集合命令文档命令 mongoosemongoose的使用插入字段类型mongoose字段验证与强制性设置删除文档更新文档读取数据条件控制 后记 概述 Mongodb是一个分布式文件存储的数据库。 官网:M…

使用 AI 修复去除不需要的对象

Inpainting 是一种运用了稳定扩散(Stable Diffusion)技术来部分重绘图像的方法。简单来讲需准备一张图像,绘制一块遮罩以标明想要重绘的图像区域,同时提供一些重绘提示。随后稳定扩散就能根据这些提示,重新绘制遮罩区域…

layui(5)——内置模块分页模块

模块加载名称&#xff1a;laypage laypage 的使用非常简单&#xff0c;指向一个用于存放分页的容器&#xff0c;通过服务端得到一些初始值&#xff0c;即可完成分页渲染&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset&quo…

聊一聊mysql的MVCC

技术主题 在mysql世纪使用中&#xff0c;经常涉及到MVCC的概念&#xff08;Multi-Vsersion Concurrency Control&#xff09;&#xff0c;即多版本并发控制&#xff0c;一种并发控制方法&#xff0c;根本目的是主为了提升数据库的并发性能。 mvcc为什么产生 数据库最原生的锁…

设计模式大全

使用设计模式的目的&#xff1a; 程序猿在编码的过程中面临着来自耦合性、内聚性、可维护性、可扩展性、重用性、灵活性等多方面的挑战。设计模式是为了让程序具有更好的&#xff1a; 1&#xff09;重用性&#xff0c;即相同功能的代码编写一次即可&#xff0c;不用重复编写 …

3-JVM 运行时数据区

目录 1.堆&#xff08;线程共享&#xff09;&#xff08;最大的一块区域&#xff09; 2.Java虚拟机栈&#xff08;线程私有&#xff09; 3.本地方法栈&#xff08;线程私有&#xff09; 4.程序计数器&#xff08;线程私有&#xff09; 5.方法区&#xff08;线程共享&#…

Oracle JSON_ARRAYAGG()函数的默认排序问题

引入&#xff1a; 在实际操作中&#xff0c;俺写了这样一个Funtcion&#xff1a; FUNCTION fun_get_xxx(v_param_one VARCHAR2) RETURN CLOB ASv_OUTPUT CLOB;BEGINWITH temp_table AS (SELECT * FROM (( SELECT one.action_id,two.log_timeFROM table_one oneLEFT JOIN table…

Python程序设计基础:字符串

文章目录 一、字符串二、字符串的索引与切片三、字符串处理与操作四、format()格式化方法五、字符串与数值的转换 一、字符串 在Python中&#xff0c;使用单引号或双引号括起来的内容&#xff0c;称为字符串类型数据&#xff08;str&#xff09;&#xff0c;可以使用以下4种方…

Linux主分区,扩展分区,逻辑分区的联系和区别

基本概念 硬盘分区有三种&#xff0c; 主磁盘分区、扩展 磁盘分区、 逻辑分区。 一个 硬盘 主分区至少有1个&#xff0c;最多4个&#xff0c;扩展分区可以没有&#xff0c;最多1个。且 主分区扩展分区总共不能超过4个。 逻辑分区可以有若干个。 在windows下激活的 主分区是 …

树形结构-二叉树结构

树形结构 树形结构简介 树结构是一种非线性储存结构&#xff0c;存储的是具有“一对多”关系的数据元素的集合 树的相关术语 结点&#xff08;Node&#xff09; 使用树结构存储的每一个数据元素被成为“结点” 结点的度&#xff08;Degree of Node&#xff09; 某个结点所拥…

一次完整的Loadrunner基本流程操作

目录 一.生成脚本&#xff1a; 二.回放脚本&#xff1a; 三.创建场景&#xff1a; 四.生成报告&#xff1a; Loadrunner基本流程操作 准备条件&#xff1a; 一.安装loadrunner 二.破解loadrunner &#xff08;注&#xff1a;本次使用lr11版本可以兼容的IE浏览器版本为I…

Qt简单讲解项目结构

Qt简单讲解项目结构 项目结构 主函数入口 #include "mainwindow.h"#include <QApplication>// 程序入口 argc 表示命令行变量的数量 argv表示命令行变量的数组 int main(int argc, char *argv[]) {// a表示应用程序对象QApplication a(argc, argv);MainWin…

绿色节能数据中心供配电系统设计

随着新一代信息技术的快速发展&#xff0c;数据资源存储、计算和应用需求大幅提升&#xff0c;机房在各个领域都有着广泛的应用&#xff0c;如学校内有专用机房、通信类企业有通信机房等。近年来&#xff0c;国家对新型数据中心机房建设也越来越重视&#xff0c;据工信部、国家…

Flutter私服搭建之package查询

温馨提示&#xff1a;这是一篇私有的package客户端查询的平台搭建文章&#xff0c;牵扯到python中的Djiango框架&#xff0c;虽和Flutter相关&#xff0c;但客户端的代码并没有关联&#xff0c;请您根据需要进行阅读。 公有的package&#xff0c;对于一个Flutter开发者而言&…

centos + lnmp + tp6部署的项目,访问的时候经常出现No input file specified

1.检查路径设置 检查你的 Nginx 配置文件是否正确指定了 PHP 路径&#xff0c;确认文件路径是否正确。同时&#xff0c;确保你的 Web 服务器具有访问权限。 server { listen 80; server_name example.com; root /usr/share/nginx/html; index index.html ind…