网站开发报价表格,wordpress 翻页功能,网站 html,哈尔滨做平台网站平台公司哪家好在这一篇文章中#xff0c;我们从源码的角度再次理解下 setState 的更新机制#xff0c;供深入研究学习之用。 在上一篇手记「深入理解 React JS 中的 setState」中#xff0c;我们简单地理解了 React 中 setState “诡异”表现的原因。 源码的部分为了保证格式显示正常就截… 在这一篇文章中我们从源码的角度再次理解下 setState 的更新机制供深入研究学习之用。 在上一篇手记「深入理解 React JS 中的 setState」中我们简单地理解了 React 中 setState “诡异”表现的原因。 源码的部分为了保证格式显示正常就截图了查看源码点击对应的链接直接跳转至 GitHub 查看即可。 1. React 中的 setState 更新逻辑代码 在更新逻辑的部分可以看到 React 会通过 batchingStrategy.isBatchingUpdates 判断当前的逻辑状态下是否需要进行批量更新。 如果不是那么就直接进行页面的批量更新将之前累积的所有状态一次更新到组件上。就是类似我们上一篇文章中举例的快递点一次将所有的快递寄出。如果是那么所有的组件状态不进行立即更新而是将组件状态存放在一个叫 dirtyComponents 的数组中去等待下次更新时机的到来再进行更新。 源码地址 2. React 中的 Transaction 设计 为了实现上述的更新逻辑React 设计了 Transaction 的逻辑看起来也像是数据库中的事务。 源码中如图所示给出了一幅图以及大段的解释。 React 将整个的函数执行过程包裹上了 Transaction在函数执行前与执行后分别有 initialize 和 close 两个方法。 这样的话 React 就有时机在函数执行过程中涉及到 setState 的执行都将缓存下来在 close 的时候进入到 React 的 state 更新逻辑进行更新判断操作并最终更新到前台的 DOM 上。 源码地址 其实 Virtual DOM 的框架都会有这样的设计逻辑理解了这样的底层设计才能很好地理解一些方法在前台的表现行为。 Vue.js 中也有类似的设计逻辑后续如果有时间我们将继续进行相关讨论。 下一篇文章我们继续来看 React 底层是如何进行 batchingStrategy 的设计以及更新状态的转换的。 转载于:https://www.cnblogs.com/parry/p/8891478.html