Vue2、Vue3的Diff算法比较

前言

diff算法是vue更新dom前,比较新旧vdom的一种优化方式

特点:

  1. 只会在同一级比较

  2. 从两边往中间收拢

差别

  • vue2 和 vue3的差别在于处理完头尾节点后,对设于节点的处理方式
  • vue2 是遍历旧节点,将旧节点映射到map里,然后再遍历新节点,看是否有可以复用的再打上补丁
  • vue3 是建立一个 新节点的剩余节点在旧节点中的位置 的数组,然后通过数组找到一个最长递增子序列,然后这个序列的节点不动,再去移动剩下的节点。

最长递增子序列

js 复制代码
function lengthOfLIS(nums) {
  const n = nums.length;
  if (n === 0) return 0;

  const dp = new Array(n).fill(1);

  for (let i = 1; i < n; i++) {
    for (let j = 0; j < i; j++) {
      if (nums[i] > nums[j]) {
        dp[i] = Math.max(dp[i], dp[j] + 1)
      }
    }
  }

  return Math.max(...dp);
}
相关推荐
喵呜嘻嘻嘻10 小时前
Gurobi求解器参数
java·数据结构·算法
产品经理邹继强11 小时前
VTC财务与投资篇②:预算革命——如何用三维算法决定每一分钱去哪
算法
Polaris北11 小时前
第二十四天打卡
算法
Anastasiozzzz11 小时前
G1垃圾回收流程详解
java·开发语言·算法
滴滴答滴答答12 小时前
LeetCode Hot100 之 17 有效的括号
算法·leetcode·职场和发展
掘根12 小时前
【C++STL】二叉搜索树(BST)
数据结构·c++·算法
老鼠只爱大米12 小时前
LeetCode经典算法面试题 #20:有效的括号(数组模拟法、递归消除法等五种实现方案详细解析)
算法·leetcode··括号匹配·数组模拟法·递归消除法
yxc_inspire12 小时前
2026年寒假牛客训练赛补题(五)
算法
不想看见40412 小时前
6.3Permutations -- 回溯法--力扣101算法题解笔记
笔记·算法·leetcode
诗词在线12 小时前
孟浩然诗作数字化深度实战:诗词在线的意象挖掘、检索优化与多场景部署
大数据·人工智能·算法