当前位置: 首页 > article >正文

【VUE】Vue3中的diff流程

在Vue3中,Diff流程主要分为两个阶段:标记阶段和应用阶段。其中标记阶段是用来比较新老VNode树的差异,并记录下来需要进行的具体操作;应用阶段则是将这些具体操作应用在真实DOM上,完成页面的更新。

具体来说,Vue3中的diff算法步骤如下:

标记阶段

  • 遍历新老VNode树:对于新老VNode树进行深度优先遍历,将每个VNode节点进行比较。
  • key的比较:如果新老VNode的key不同,则认为这两个节点是不同的,直接跳过。
  • 类型的比较:如果新老VNode的类型不同,则认为这两个节点是不同的,直接跳过。
  • 跳过相同节点:如果当前新老VNode节点是相同的,则继续递归比较其子节点。
  • 标记复用节点:如果找到一个新的VNode节点可以与某个旧的VNode节点复用,则将该旧节点从节点池中删除并记录复用节点。
  • 创建新节点:如果新的VNode节点不能复用任何一个旧的VNode节点,则创建一个新的VNode节点并记录它。
  • 记录移动节点:如果新的VNode节点不能复用任何一个旧的VNode节点,并且每个旧节点都不等于新节点,则记录需要移动的节点。

应用阶段

  • 执行patchFn函数:在应用阶段中,Vue3将根据标记阶段中生成的具体操作(如创建、更新、删除节点等)执行patchFn函数,实现对真实DOM的修改和更新。
  • 更新子节点:如果当前节点有子节点,则递归调用diff算法进行子节点的比较和更新。
  • 删除节点:如果当前VNode节点被标记为需要删除,则将该节点从父节点中删除,并销毁其对应的真实DOM节点。
  • 创建节点:如果当前VNode节点是新创建的,则根据其类型、属性和子节点创建对应的真实DOM节点,并插入到父节点中。
  • 移动节点:如果当前VNode节点需要移动到其他位置,则将其从原先的位置移动到目标位置。这通常是通过插入或删除元素来实现的。

综上所述,Vue3中的diff算法主要通过对新老VNode树的key、类型以及内容进行比较,实现对节点的创建、更新、移动和删除等一系列具体操作,从而优化页面渲染的性能和效率。


http://www.kler.cn/news/343017.html

相关文章:

  • No.10 笔记 | PHP学习指南:PHP数组掌握
  • Linux的环境与历史
  • Label Studio 半自动化标注
  • 2-119 基于matlab的合成孔径雷达(SAR)RDA(距离多普勒算法)、RMA(距离徙动算法)、CSA(线性调频变标算法)算法点目标成像与分析
  • 搭建一个高效的 TikTok 节点:从零开始的实践指南
  • 10月10日
  • ECharts 实例对象中的所有选项配置详解
  • 前端reactvue3——实现滚动到底加载数据
  • 高级java每日一道面试题-2024年10月7日-框架篇[springboot篇]-springboot如何处理循环依赖的问题?
  • VVIC商品详情接口技术解析与实战代码示例
  • 数据结构——顺序表的实现
  • merlion的dashboard打开方法
  • 微服务之间的相互调用的几种常见实现方式对比
  • Qt实现侧边栏功能
  • html+css+js实现Slider滑块
  • detectron2/data/catalog.py源码笔记
  • 基于SpringBoot健身房管理系统【附源码】
  • 山西农业大学20241010
  • SAP学习笔记 - 豆知识11 - 如何查询某个字段/DataElement/Domain在哪个表里使用?
  • Qt 如何优雅的设置qtablewidget qtableview某列不可编辑、只读?