©
本文档使用
php.cn手册 发布
在大多数情况下,我们建议使用受控组件来实现表单。在受控组件中,表单数据由React组件处理。另一种选择是不受控制的组件,其中表单数据由DOM本身处理。
要编写一个不受控制的组件,而不是为每个状态更新编写一个事件处理程序,可以使用ref从DOM获取表单值。
例如,该代码在不受控制的组件中接受单个名称:
class NameForm extends React.Component { constructor(props) { super(props); this.handleSubmit = this.handleSubmit.bind(this); } handleSubmit(event) { alert('A name was submitted: ' + this.input.value); event.preventDefault(); } render() { return ( <form onSubmit={this.handleSubmit}> <label>Name:<input type="text" ref={(input) => this.input = input} /></label> <input type="submit" value="Submit" /></form> ); } }
在CodePen上试用它。
由于不受控制的组件在DOM中保留了真相源,因此在使用不受控制的组件时,集成React和非React代码有时更容易。如果你想快速和肮脏,它也可以少一点代码。否则,您通常应该使用受控组件。
如果仍然不清楚您应该在特定情况下使用哪种类型的组件,那么您可能会发现这篇关于受控与非受控输入的文章会有所帮助。
在React渲染生命周期中,value
表单元素上的属性将覆盖DOM中的值。对于不受控制的组件,您通常希望React指定初始值,但让后续更新不受控制。要处理这种情况,您可以指定一个defaultValue
属性而不是value
。
render() { return ( <form onSubmit={this.handleSubmit}> <label>Name:<input defaultValue="Bob" type="text" ref={(input) => this.input = input} /> </label> <input type="submit" value="Submit" /></form> ); }
同样,<input type="checkbox">
和<input type="radio">
支持defaultChecked
,并<select>
与<textarea>
支持defaultValue
。