Reactjs 是使用更改处理程序的更好方法
Reactjs which is the better way to use change handler
所以我知道有几种方法可以做到这一点,但我想知道哪种方法更好或更适合创建搜索栏组件?你能解释一下为什么吗?我是新手,看过教程和其他教程,每个人都对处理程序进行了一些不同的更改。
state = {
term: '',
};
onChange = this.onChange.bind(this);
onChange(e) {
console.log(e.target.value);
this.setState({ term: e.target.value });
};
<input
value={this.state.term}
onChange={this.onChange}
/>
我觉得这种方式可能会更好,因为它允许您为多个不同的状态重用 onChange 处理程序。
state = {
term: '',
};
onChange = name => e => {
this.setState({ [name]: e.target.value });
};
<input
value={this.state.term}
onChange={this.onChange('term')}
/>
为了重用 onChange
处理程序,下面的代码会更合适也更好。
onChange = e => {
this.setState({
[e.target.name]: e.target.value
});
};
<input type="text" name="name" onChange={(e)=>this.onChange(e)} />
所以我知道有几种方法可以做到这一点,但我想知道哪种方法更好或更适合创建搜索栏组件?你能解释一下为什么吗?我是新手,看过教程和其他教程,每个人都对处理程序进行了一些不同的更改。
state = {
term: '',
};
onChange = this.onChange.bind(this);
onChange(e) {
console.log(e.target.value);
this.setState({ term: e.target.value });
};
<input
value={this.state.term}
onChange={this.onChange}
/>
我觉得这种方式可能会更好,因为它允许您为多个不同的状态重用 onChange 处理程序。
state = {
term: '',
};
onChange = name => e => {
this.setState({ [name]: e.target.value });
};
<input
value={this.state.term}
onChange={this.onChange('term')}
/>
为了重用 onChange
处理程序,下面的代码会更合适也更好。
onChange = e => {
this.setState({
[e.target.name]: e.target.value
});
};
<input type="text" name="name" onChange={(e)=>this.onChange(e)} />