React虚拟DOM是什么?是如何提升性能的
创作时间:
作者:
@小白创作中心
React虚拟DOM是什么?是如何提升性能的
引用
1
来源
1.
https://www.cnblogs.com/94pm/p/18761492
React虚拟DOM是React框架的核心概念之一,它通过使用JavaScript对象来表示真实DOM的结构,从而实现高效的性能优化。本文将详细介绍虚拟DOM的工作原理及其三个核心策略:树形结构同层比较、相同类型节点的处理以及列表diff算法,帮助读者深入理解React如何通过最小化DOM操作来提升应用性能。
虚拟DOM的工作原理
虚拟DOM是React的核心概念,它使用JavaScript对象来反应真实DOM的结构。当组件的状态变更后,React会计算出新的虚拟DOM树,并跟前一次的虚拟DOM树进行对比,找出差异(也就是需要更新的部分),最后仅将这些差异应用到真实DOM中。通过这种方式,React避免了对真实DOM的频繁操作,从而提高了性能。
ReactDOM Diff算法核心思想
核心策略一:树形结构同层比较,不跨层对比
React默认认为:
- 不同层级的DOM结构几乎不会移动。
- 如果节点层级发生变化,直接销毁原来的DOM,重新创建。
如上图所示,当A需要移动到D下面时,React会先删除A,然后再到D节点中创建A。
核心策略二:相同类型节点,保留,更新属性;不同类型节点,销毁再创建
如上图:当
component D的位置
换成了
component G
后,即使两者的结构非常类似,也会将
D
删除再重新创建
G
核心策略三:列表 diff,通过 key 提升性能
- 对比新旧列表的长度:如果新旧列表 长度不同,则肯定有增删元素;
- 使用
key
属性来唯一标识每个节点。
key
的作用是帮助 React 判断一个节点是否在新旧列表中相同,从而决定是否 复用、删除 或 插入 节点
基于key的移动算法策略: 只要遍历新列表的时候,老列表的顺序还能顺着走(即索引是递增的),就说明顺序还是对的,不需要移动节点。一旦需要回头,说明老列表里的顺序不满足新列表了,就需要移动
以上图为例,比较过程如下:
新集合遍历到的节点 在老集合中的索引 lastPlacedIndex(期望递增) 是否需要移动
b 1 1 否
a 0 1 是
d 3 1 否
c 2 3 是
- b→ 老集合索引是 1,不动。
- a→ 老集合索引是 0,发现索引不递增(<lastPlacedIndex),触发移动。
- d→ 老集合索引是 3,不动。
- c→ 老集合索引是 2,索引不是递增(应该大于3),触发移动。
// 模拟的新旧节点集合
const oldList = ['a', 'b', 'c', 'd'];
const newList = ['b', 'a', 'd', 'c'];
// 用于存储老集合节点在新集合中的索引
let lastPlacedIndex = -1; // 初始时没有节点被处理过
// 遍历新集合
newList.forEach((newNode, newIndex) => {
// 查找新节点在老集合中的位置
const oldIndex = oldList.indexOf(newNode);
// 判断是否需要移动
if (oldIndex < lastPlacedIndex) {
// 需要移动,因为索引不再递增
console.log(`节点 ${newNode} 需要移动`);
} else {
// 不需要移动
console.log(`节点 ${newNode} 不需要移动`);
}
// 更新 lastPlacedIndex
lastPlacedIndex = Math.max(lastPlacedIndex, oldIndex);
});
热门推荐
壬午日禄马同乡在哪柱最吉,禄马同乡命局详解!
保障日常饮水安全,NSF P535认证产品为可靠之选
Excel中千米转换成公里的多种方法
吗丁啉什么时候吃?饭前还是饭后?
活见鬼:从传说、文化到科学探索
研究人员发现三种主要失智症共有的细胞机制
如何为老年失智症长者进行认知康复训练?
唐朝三省六部制的特点及其各部职能详解
正宗的铁棍山药原产地是哪里?中国好山药,道地看温县
如何防小人(如何防小人背后使坏)
i5-12600K和i5-12600KF有什么区别?哪个更适合游戏?
肝内胆管癌靶向治疗:一种精准医疗新选择
神经损伤的治疗新希望:神经修复技术助力康复
华为如何收集情报?
外服大威力副武器BFR手枪,近距离一发秒人!
DeepSeek核心技术(二) MoE(混合专家模型)| 近4千字翻译+解释
八卦方位图-全解八卦口诀,代表方向,先天和后天八卦的差别等
如何解决功放过热问题?这种维修方法有哪些注意事项?
最新图像显示菲非法"坐滩"船只锈蚀极为严重 专家:或对海洋生物造成不可逆伤害
电池用万用表如何测量?测量时需注意哪些问题?
苜蓿草种植全攻略:最佳种植时间与技巧详解
傅科摆为什么能够证明地球在自转 实验原理是什么
10公里等于多少千米?跑步世界里的距离真相
中医药材的种类和应用
梵高绘画风格特点是什么
使用可以显著降低尿蛋白的非奈利酮,至少要知道这些问题!
Fgo国服哪年开的——揭秘历史与发展历程
Word打印出的内容和文档不一致怎么办?
如何轻松撕开不干胶?有哪些方法可以提高撕开的效率?
通信系统中的SERDES和PHY芯片:功能、特性和应用