首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React this.input.value与句柄更改

React this.input.value与句柄更改
EN

Stack Overflow用户
提问于 2017-10-04 19:21:22
回答 1查看 13.6K关注 0票数 5

还有什么更好的?

我有一个有10个输入的表格。

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

代码语言:javascript
复制
handleChange(e) {
    this.setState({input: e.target.value});
}
...
<input type="text" value={this.state.input} onChange={this.handleChange} />

代码语言:javascript
复制
onSubmit() {
    const inputValue = this.input.value;
    ...
}
...
<input type="text" ref={(input) => {this.input = input;}} />

从文件中:

什么时候使用参考文献 参考文献有几个很好的用例:管理焦点、文本选择或媒体播放。触发命令动画。与第三方DOM库集成。避免对任何可以以声明方式完成的操作使用“参考”。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-10-04 19:27:22

设置受控输入是一种痛苦,但我使用这种模式使其变得更容易一些。

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

代码语言:javascript
复制
handleInputChange(e){
    const target = e.target;
    const value = target.type === 'checkbox' ? target.checked : target.value;
    const name = target.name;
    this.setState({
        [name]: value
    });
}

然后,对于您的输入,一定要给它一个与要更新的状态中的键匹配的name

代码语言:javascript
复制
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>
    )
}
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46572616

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档