在这一篇文章中,咱们从源码的角度再次理解下 setState 的更新机制,供深刻研究学习之用。react
在上一篇手记「深刻理解 React JS 中的 setState」中,咱们简单地理解了 React 中 setState “诡异”表现的缘由。git
源码的部分为了保证格式显示正常就截图了,查看源码点击对应的连接直接跳转至 GitHub 查看便可。github
在更新逻辑的部分,能够看到 React 会经过 batchingStrategy.isBatchingUpdates
判断当前的逻辑状态下是否须要进行批量更新。数据库
若是不是,那么就直接进行页面的批量更新,将以前累积的全部状态一次更新到组件上。就是相似咱们上一篇文章中举例的快递点一次将全部的快递寄出。数组
若是是,那么全部的组件状态不进行当即更新,而是将组件状态存放在一个叫 dirtyComponents
的数组中去,等待下次更新时机的到来再进行更新。缓存
源码地址框架
为了实现上述的更新逻辑,React 设计了 Transaction 的逻辑,看起来也像是数据库中的事务。
源码中如图所示,给出了一幅图以及大段的解释。async
React 将整个的函数执行过程包裹上了 Transaction,在函数执行前与执行后分别有 initialize
和 close
两个方法。函数
这样的话 React 就有时机在函数执行过程当中,涉及到 setState 的执行,都将缓存下来,在 close
的时候进入到 React 的 state 更新逻辑进行更新判断操做,并最终更新到前台的 DOM 上。学习
其实 Virtual DOM 的框架都会有这样的设计逻辑,理解了这样的底层设计才能很好地理解一些方法在前台的表现行为。
Vue.js 中也有相似的设计逻辑,后续若是有时间咱们将继续进行相关讨论。
下一篇文章,咱们继续来看 React 底层是如何进行 batchingStrategy
的设计以及更新状态的转换的。