React - this.input.value vs handle change

时间:2017-10-04 19:21:23

标签: reactjs

什么更好?

我有一个包含10个输入的表单。

我应该使用this.input.value还是处理更改并将其存储在state

handleChange(e) {
    this.setState({input: e.target.value});
}
...
<input type="text" value={this.state.input} onChange={this.handleChange} />

onSubmit() {
    const inputValue = this.input.value;
    ...
}
...
<input type="text" ref={(input) => {this.input = input;}} />

来自文档:

  

何时使用参考

There are a few good use cases for refs:

    Managing focus, text selection, or media playback.
    Triggering imperative animations.
    Integrating with third-party DOM libraries.

Avoid using refs for anything that can be done declaratively.

1 个答案:

答案 0 :(得分:6)

设置受控输入有点痛苦,但我使用这种模式使它更容易一些。

为所有输入创建一个onChange事件处理程序:

handleInputChange(e){
    const target = e.target;
    const value = target.type === 'checkbox' ? target.checked : target.value;
    const name = target.name;
    this.setState({
        [name]: value
    });
}

然后,对于您的输入,请确保为其提供与您所在州的密钥匹配的name以进行更新。

render() {
    const { firstName, lastName, email, acceptTerms } = this.state;
    return (
        <form>
            <input name="firstName" onChange={this.handleInputChange} value={firstName} />
            <input name="lastName" onChange={this.handleInputChange} value={lastName} />
            <input name="email" onChange={this.handleInputChange} value={email} />
            <input type="checkbox" name="acceptTerms" onChange={this.handleInputChange} checked={acceptTerms} />
        </form>
    )
}