【发布时间】:2018-01-22 22:38:23
【问题描述】:
我在网上找到了一个关于 React.js 的教程,但我看到了导师在没有 setState() 函数的情况下更改状态的方式。我在这里问这是否是一个好习惯。
构造函数:
constructor(props) {
super(props);
this.state = {
uid: uuid.v1(),
name: '',
answers: {
answer1: '',
answer2: '',
answer3: ''
},
isSubmitted: false
};
this.onSubmit = this.onSubmit.bind(this);
this.answerSelected = this.answerSelected.bind(this);
this.questionSubmitted = this.questionSubmitted.bind(this);
}
他更新状态的方式是:-
answerSelected(event) {
let answers = this.state.answers;
if (event.target.name === 'answer1') {
answers.answer1 = event.target.value;
} else if (event.target.name === 'answer2') {
answers.answer2 = event.target.value;
} else if (event.target.name === 'answer3') {
answers.answer3 = event.target.value;
}
}
据我所知,React 应该使用setState({answers: {answer1: event.target.value}}) 设置状态。我对吗?有什么更好的方法?
【问题讨论】:
标签: reactjs