1、不要直接修改 State

例如,此代码不会重新渲染组件:

而是应该使用 setState():

构造函数是唯一可以给 this.state 赋值的地方

2、State 的更新可能是异步的

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

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

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

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

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

 3、State 的更新会被合并

当你调用 setState() 的时候,React 会把你提供的对象合并到当前的 state。

例如,你的 state 包含几个独立的变量:

 然后你可以分别调用 setState() 来单独地更新它们:

 这里的合并是浅合并,所以 this.setState({comments}) 完整保留了 this.state.posts, 但是完全替换了 this.state.comments

02-11 05:47