10月30号,线上大坑

mac2025-02-14  22

问题描述:线上紧急问题,在选择了受益主体后,接口并没有使用改变后的受益主体,通过定位发现,子组件中改变受益主体的地方,当受益主体变化,设置了setState使其受益主体改变,但是下面当一个方法将子组件改变当属性传给父组件时值并没有变

分析原因:其关键在于setState是异步的,设置之后并不能马上拿到它的值,setState 方法其实是 “异步” 的。即立马执行之后,是无法直接获取到最新的 state 的,需要经过 React 对 state 的所有改变进行合并处理之后,才会去计算新的虚拟dom,再根据最新的虚拟dom去重新渲染真实dom。

解决方案:React为我们提供了一个回调去实现,将取值的操作放在这个回调函数中。原因是该回调的执行时机在于state合并处理之后

总结:对setState机制原理不熟悉,导致花费了大量时间

最新回复(0)