React Virtual Dom & Diff Algorithm

什么是Virtual DOM

Virtual DOM只是真实Dom的副本,它不是Javascript的标准概念,更像是专门为了React设计的概念,可以称之为Virtual React DOM。它是一个节点树, 每个节点存储了对应节点的部分信息并且实现了React interfaces。部分与React相关的API也会存储在Fiber结构中,因此Fibers是Virtual DOM的组成部分。
节点树主要是为了服务于Diff算法,最小化页面更新,提升性能。

  1. 刷新页面(比如通过setState)
  2. 生成节点树
  3. Diff 算法
  4. 计算出minimal render operation
  5. render ( to DOM, iOS, or Android)
    以上第一步到第四步均属于reconciler,第五步属于renderer

Diff Algorithm

React 如何使本该是 O(n3)的计算优化成O(n)

  1. 首先检查同级节点类型,如果节点类型发生改变,直接全部重新生成, 而且销毁之前的节点,之前的节点组件及其所有子组件componentWillUnmount触发, 新组件及其所有子组件UNSAFE_componentWillMount ,componentDidMount相继触发
  2. 如果节点类型相同,检查节点属性,仅更新发生改变的节点
  3. 如果子节点是list,默认情况下(没有 key),React会按序比较两个列表,比如,列表末尾插入,React仅插入一个节点,若列表头插入,React会修改所有节点。
  4. 如果子节点是list,并且存在key,React在比较列表是,不会按序比较,而且类似比较key-element。

Element List with Index Key

日常开发时,有的小伙伴会使用index作为key,这是不太好的习惯,主要是因为两点:

  1. 如上所说,使用index作为key,list一旦重排(中间插入,末尾插入,中间删除,混序)皆会导致不必要的其他list item的更新,耗费性能
  2. 对于一组uncontrolled input list,加入顺序发生变化,但两个list实际上看不出差别,因此React不会更新,那么页面上显示的input顺序也不会更新 demo
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容