Reactjs 这是使用更改处理程序的更好方法

标签 reactjs onchange

所以我知道有几种方法可以做到这一点,但我想知道哪种是更好或更合适的方法来创建搜索栏组件?您能解释一下原因吗?我是 react 新手,看过教程等等,每个人对处理程序的更改都略有不同。

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)} />

关于Reactjs 这是使用更改处理程序的更好方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51683504/

相关文章:

javascript - jQuery - autoNumeric 插件,自动从 .autoNumeric ('set' 触发 .change() ,值)

jquery - 如何设置jquery所见即所得更改事件?

reactjs - TypeScript 中的 'value' 上不存在属性 'EventTarget'

javascript - 无论使用何种方法,Github Pages 和 React App 都无法工作

reactjs - 登录后立即缺少权限错误消息

reactjs - 找不到图标react-fontawesome

javascript - 根据 React.Js 中第一个下拉列表中的选择填充第二个下拉列表

javascript - 我可以将选择值作为参数传递给 onchange 函数吗?

javascript - jQuery 'change' 事件

python - text.on_change 对 Bokeh TextInput 没有响应