扯扯React的setState

先看一个例子

constructor(props) {
    super(props);

    this.state = {
      click:0
    };
}

render() {
    console.log('render');
    return (
        <div>
          <p onClick={this.handleClick.bind(this)}>click:{this.state.click}</p>
        </div>
    )
}

handleClick() {
    this.setState({
      click:this.state.click + 1
    });
    this.setState({
      click:this.state.click + 1
    }); 
}

最后显示不是2,而是1


image.png

Why?

state机制

当setState后,state并不是立即变化,而是进行batchUpdate,而且还进行了合并

所以要做如下修改

handleClick() {
    this.setState((prevState,props)=>({
      click:prevState.click + 1
    }));
    this.setState((prevState,props)=>({
      click:prevState.click + 1
    }));
}

setState设置callbak回调函数

回调函数会在state更新后进入

handleClick() {
    this.setState({
      click:2
    }, ()=>{console.log('finish')});
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容