key 属性, 这样React就可以方便地比对出插入或删除项了.关于 key 属性, 应稳定、可预测且在列表内唯一(无需全局唯一), 如果数据有ID的话直接使用此ID作为 key, 或者利用数据中的一部分字段哈希出一个....2.2 递归的Diffing在1.2节中的虚拟DOM对象中可以得知: 虚拟DOM树的每个节点通过 children 属性构成了一个嵌套的树结构, 这意味着要以递归的形式遍历和比较新旧虚拟DOM树.2.1..., 将待调用的函数加入执行队列, 浏览器将在不影响关键事件处理的情况下逐个调用.考虑到浏览器的兼容性以及 requestIdleCallback 方法的不稳定性, React自己实现了专用于React的类似...Fiber从概念上来说, Fiber就是重构后的虚拟DOM节点, 一个Fiber就是一个JS对象.Fiber节点之间构成 单向链表 结构, 以实现前文提到的几个特性: 更新可暂停/恢复、可跳过、可设优先级....3.1 Fiber节点一个Fiber节点就是一个JS对象, 其中的关键属性可分类列举如下:结构信息(构成链表的指针属性)return: 父节点child: 第一个子节点sibling: 右侧第一个兄弟节点