此处登录的状态正在更新,因为我正在根据状态更改按钮.但是每当我在更改它后立即登录控制台登录状态的值时,它就会显示相反的情况.因此,如果loggedIn只是因为它在控制台中仍然显示为false.它背后的原因是什么?
constructor(props) {
super(props);
this.state = {
loggedIn: false
}
}
changeState(val){
this.setState({
loggedIn: val
});
console.log(this.state.loggedIn);
}
render() {
return (
this.state.loggedIn ? <Home_user onUpdate={(e) => this.changeState(e) } /> : <Auth onUpdate={(e) => this.changeState(e) } />
)
}
Run Code Online (Sandbox Code Playgroud)
Zek*_*oid 17
设置状态是异步的,因此您几乎总能看到旧值.而是使用函数提供的回调:
this.setState({
loggedIn: val
}, () => console.log(this.state.loggedIn));
Run Code Online (Sandbox Code Playgroud)
当您需要在设置新状态后执行某些操作时,此功能特别有用.
| 归档时间: |
|
| 查看次数: |
3720 次 |
| 最近记录: |