温习react文档(v0.17)

前言:自己当初学习的react的还是0.8.x版本,如今技术日新月异,react已经进化到v17.x版本。很多语法已经跟之前不同,所以重新温习一下

 

State 的更新可能是异步的

出于性能考虑,React 可能会把多个 setState() 调用合并成一个调用。

因为 this.props 和 this.state 可能会异步更新,所以你不要依赖他们的值来更新下一个状态。

例如,此代码可能会无法更新计数器:

// Wrong
this.setState({
  counter: this.state.counter + this.props.increment,
});

要解决这个问题,可以让 setState() 接收一个函数而不是一个对象。这个函数用上一个 state 作为第一个参数,将此次更新被应用时的 props 做为第二个参数:

// Correct
this.setState((state, props) => ({
  counter: state.counter + props.increment
}));

上面使用了箭头函数,不过使用普通的函数也同样可以

 

上一篇:【Qt 】Qt 信号和槽详解


下一篇:2021-05-23