setState的机制问题?

书上看到直接调用this.setstate和在setTimeout里面调用结果不一样,是因为它们走的逻辑不一样。书上说到调用栈,为什么setTimeout前置没有调用batchUpdate呢?

阅读 1.4k
1 个回答

首先先说结论,setTimeout或者ajax之类的异步函数都不会调用batchUpdate,因为React控制不了timer之类的事件。

实际上在你的函数里面,React做了不少处理,首先把你的函数包装成一个Transaction,在Transacion的initialize阶段建立起一个update queue(并设置isBatchingUpdates为true),然后在close阶段将isBatchingUpdates设置为false,并统一触发更新。

而在timer之类的回调函数里面React做不了这一步操作,所以就没有调用batchUpdate。

当然,这个可能在16版本引入fiber之后“优化”掉,不过也只是可能。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题