在大多数情况下,我们推荐使用受控组件来实现表单。在受控组件中,表单数据由 React
组件负责处理。另外一个选择是不受控组件,其表单数据由 DOM
元素本身处理。
要编写一个未控制组件,你可以使用一个 ref
来从 DOM 获得 表单值,而不是为每个状态更新编写一个事件处理程序。
例如,在不受控组件中,以下代码接受一个单独的名字 :
class NameForm extends React.Component { constructor(props) { super(props); this.handleSubmit = this.handleSubmit.bind(this); this.input = React.createRef(); } handleSubmit(event) { alert('A name was submitted: ' + this.input.current.value); event.preventDefault(); } render() { return ( <form onSubmit={this.handleSubmit}> <label> Name: <input type="text" ref={this.input} /> </label> <input type="submit" value="Submit" /> </form> ); } }
因为不受控组件的数据来源是 DOM 元素,当使用不受控组件时很容易实现 React 代码与非 React 代码的集成。如果你希望的是快速开发、不要求代码质量,不受控组件可以一定程度上减少代码量。否则。你应该使用受控组件。
在 React 渲染生命周期中,表单元素中的 value
属性将会覆盖 DOM 中的 value
。在不受控组件中,你可能希望 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
。
在HTML中,<input type="file">
可以让用户从其设备存储中选择一个或多个文件上传到服务器,或通过File API进行操作。
<input type="file" />
在React中,<input type="file" />
始终是一个不受控制的组件,因为它的值只能由用户设置,而不是以编程方式设置。
您应该使用File API与文件进行交互。 以下示例显示如何创建ref节点以访问提交处理程序中的文件:
您应该使用 File API 与文件进行交互。以下示例显示如何创建 ref 给DOM节点 以访问提交处理程序中的 file(s) :
class FileInput extends React.Component { constructor(props) { super(props); this.handleSubmit = this.handleSubmit.bind(this); this.fileInput = React.createRef(); } handleSubmit(event) { event.preventDefault(); alert( `Selected file - ${ this.fileInput.current.files[0].name }` ); } render() { return ( <form onSubmit={this.handleSubmit}> <label> Upload file: <input type="file" ref={this.fileInput} /> </label> <br /> <button type="submit">Submit</button> </form> ); } } ReactDOM.render( <FileInput />, document.getElementById('root') );
本文作者:毛超颖
本文链接:
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!