虚拟 DOM 的 diff 比对以节点为单位、同层同标签优先判断复用,通过 key 精准识别节点身份,配合细粒度 patch 和短路优化,将时间复杂度从 O(n³) 降至接近 O(n)。
虚拟 DOM 的 diff 比对不是逐像素或逐属性扫描,而是以“节点”为基本单位,按层级结构组织比较。所谓“以标签为单位的优化”,核心在于:**先快速判断节点是否可复用,再决定是否深入比对子树**——这直接跳过大量冗余计算。
diff 不会跨级查找匹配(比如旧树中某 div 的孙子节点,不会去新树的父级找对应)。它严格按深度优先顺序,逐层对齐位置:
<div>,新节点是 <span>,直接判定为“类型不一致”,整棵子树被卸载重建,不递归比对内部<div>,才进入下一步:比 key、比 props、比 children当一组子节点都是相同标签(如多个 <li>),key 就成为区分身份的唯一依据:
[{tag:'li', key:'a', text:'苹果'}, {tag:'li', key:'b', text:'香蕉'}]
[{tag:'li', key:'b', text:'香蕉'}, {tag:'li', key:'a', text:'苹果'}]
一旦确认是同一节点(标签名 + key 相同),diff 就不再新建节点,而是就地更新:
node.textContent
遇到简单结构,diff 会跳过子节点遍历:
text: 'hello')→ 清空旧 children,设 textContent