我在玩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