在咱们阅读文档的时候,大多都说react的setState是异步的,但是它真的是异步的吗?若是是,那咱们还能够猜测:那能够不能够同步?那何时须要异步,何时须要同步呢?
咱们先来看下react的官方对setSate的说明:react
将setState()认为是一次请求而不是一次当即执行更新组件的命令。为了更为可观的性能,React可能会推迟它,稍后会一次性更新这些组件。React不会保证在setState以后,可以马上拿到改变的结果。
一个很经典的例子:异步
// 初始state.count 当前为 0 componentDidMount(){ this.setState({count: state.count + 1}); console.log(this.state.count) }
若是你熟悉react,你必定知道最后的输出结果是0,而不是1。性能
咱们再来看一个例子学习
class Demo extends Component { constructor(props) { super(props); this.state = { number: 0 }; } render() { return <button ref="button" onClick={this.onClick.bind(this)}>点我</button>; } componentDidMount() { //手动绑定mousedown事件 this.refs.button.addEventListener( "mousedown", this.onClick.bind(this) ); //setTimeOut setTimeout(this.onClick.bind(this), 1000); } onClick(event) { if (event) { console.log(event.type); } else { console.log("timeout"); } console.log("prev state:", this.state.number); this.setState({ number: this.state.number + 1 }); console.log("next state:", this.state.number); } } export {Demo};
在这个组件中采用3中方法更新statethis
1.在div节点中绑定onClick事件 2.在componentDidMount中手动绑定mousedown事件 3.在componentDidMount中使用setTimeout调用onClick
在点击组件后,你能够猜到结果吗?输出结果是:code
timeout prev state: 0 next state: 1 mousedown prev state: 1 next state: 2 click prev state: 2 next state: 2
结果彷佛有点出人意料,三种方式只有在div上绑定的onClick事件输出了能够证实setState是异步的结果,另外两种方式显示setState彷佛是同步的。component
总结:
1.在组件生命周期中或者react事件绑定中,setState是经过异步更新的。
2.在延时的回调或者原生事件绑定的回调中调用setState不必定是异步的。生命周期
这个结果并不说明setState异步执行的说法是错误的,更加准确的说法应该是setState不能保证同步执行。事件
我的学习总结,有错误的地方欢迎指正٩̋(๑˃́ꇴ˂̀๑)