首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React从另一个州获得状态值

React从另一个州获得状态值
EN

Stack Overflow用户
提问于 2020-06-18 10:00:58
回答 4查看 193关注 0票数 1

我正在使用React ,目前我想执行如下操作:

代码语言:javascript
复制
constructor(props) {
    super(props);
        this.state = {
          Final: 0,
          TotalCount: 30,
        };
}

function = () => {
this.setState({Final: (this.state.TotalCount / 10) +1 });
}

我预计Final的结果将是4,但它是1,是语法错误,还是不能像这样执行操作?(很抱歉使用荒谬的语法,因为我的基础是C#)

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2020-06-18 10:09:59

我最好的猜测是,您在构造函数中调用setState,就在声明状态之后,而不是在componentDidMount

代码语言:javascript
复制
componentDidMount() { this.setState({Final: (this.state.TotalCount / 10) +1 }) }

请注意,因为setState是异步调用(它不是立即运行,而是告诉组件它应该重新呈现一个新状态),如果有一些依赖状态的东西,您应该在下一个生命周期对它们进行操作,以确保状态在之前更新。

票数 1
EN

Stack Overflow用户

发布于 2020-06-18 10:02:53

在设置状态本身时,应使用以下语法访问状态:

代码语言:javascript
复制
this.setState((state) => ({Final: (state.TotalCount / 10) +1 }))

如下文所述:

https://reactjs.org/docs/react-component.html#setstate

票数 1
EN

Stack Overflow用户

发布于 2020-06-18 10:20:10

代码语言:javascript
复制
this.setState(prev => ({ ...prev, Final: parseInt(prev.TotalCount / 10) + 1 }))

setState基本上接受回调,它从当前状态返回更新的状态,也因为除法在那里,所以安全地除以获得整数并返回更新的状态。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62447417

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档