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);
}
相关推荐
WZ188104638691 分钟前
LeetCode第20题
算法·leetcode
像素猎人3 分钟前
字符串/字符与整型数据的相互转换stoi/stol()和to_string()
c++·算法
吕司13 分钟前
LeetCode Hot Code——三数之和
数据结构·算法·leetcode
-海绵东东-15 分钟前
图论——代码篇
算法·深度优先·图论
金枪不摆鳍24 分钟前
hot100二分查找专题
数据结构·算法
YGGP26 分钟前
【Golang】LeetCode 54. 螺旋矩阵
算法·leetcode·矩阵
十八岁讨厌编程33 分钟前
【算法训练营 · 二刷总结篇】贪心算法、图论部分
算法·贪心算法·图论
没有医保李先生42 分钟前
嵌入式面试八股文整理(持续更新)
算法
mit6.8241 小时前
ai五层结构
算法
F_D_Z1 小时前
最长连续序列的长度LongestConsecutive
算法·哈希表·最长连续序列