为什么我们需要将 e.target.name 放在方括号 [] 中?

IT技术 javascript reactjs object
2021-05-07 01:22:43

为什么当我使用表单元素时,我必须将 e.target.name 放在括号中?

这是我的代码:

onChange (e) {
   this.setState({ *[e.target.name]* : e.target.value});
}

(...) 
  <div>
     <label htmlFor=""> Title : </label>
     <input type="text" name="title"  onChange={this.onChange} value={this.state.title} />
  </div>
</form>
1个回答

这是为了动态更新对象属性(当属性的名称在运行时未知时)。通过这种方式,您可以拥有多个具有不同name属性的React 输入,并使用相同的onChange处理程序来更新部分状态。

此有关

取而代之的是:

<input type="text" name="title" onChange={this.onTitleChange} value={this.state.title} />
<input type="text" name="address" onChange={this.onDescriptionChange} value={this.state.address} />
<input type="text" name="description" onChange={this.onAddressChange} value={this.state.description} />

onTitleChange (e) {
   this.setState({ title : e.target.value});
}
onAddressChange (e) {
   this.setState({ address : e.target.value});
}
onDescriptionChange (e) {
   this.setState({ description : e.target.value});
}

我们可以像您介绍的那样只编写一个处理程序:

<input type="text" name="title" onChange={this.onChange} value={this.state.title} />
<input type="text" name="address" onChange={this.onChange} value={this.state.address} />
<input type="text" name="description" onChange={this.onChange} value={this.state.description} />

onChange (e) {
   this.setState({ [e.target.name] : e.target.value});
}