我在玩React,我得到了我想要的功能,但由于无限循环某处,它非常缓慢。我相信它是在组件生命周期方法中,但我不确定如何重新格式化下面的代码以具有相同的功能,但没有无限循环。任何建议的最佳做法,将不胜感激。反应:未捕获RangeError:超出最大调用堆栈大小
class App extends Component {
constructor() {
super();
this.state = {
num: 13,
num2: 10,
total: 0
}
}
componentDidMount() {
this.addNums();
}
componentDidUpdate() {
this.addNums();
}
addNums(){
var added = parseInt(this.state.num) + parseInt(this.state.num2);
this.setState({total: parseInt(added)});
}
change(num) {
this.setState({num: num});
console.log(this.state);
}
change2(num2) {
this.setState({num2: num2});
console.log(this.state);
}
render(){
return (
<div>
<TopBar />
<Combinatoric test={this.state.num} changeNumber={this.change.bind(this)}/>
<Combinatoric test={this.state.num2} changeNumber={this.change2.bind(this)}/>
<h2>Total: {this.state.total}</h2>
<h1>hello world</h1>
</div>
);
}
}
'componentDidUpdate'调用'addNums'调用' this.setState'导致组件更新。不要在状态中存储'total' - 你总是可以在'render'中计算它 – zerkms