在 React 中,表单元素经过组件的 state 属性来本身维护 state,并根据用户输入调用setState()
来进行数据更新,使 React 的 state 成为“惟一数据源”,被 React 以这种方式控制取值的表单输入元素就叫作“受控组件”。html
class NameForm extends React.Component { constructor(props) { super(props); this.state = {value: ''}; this.handleChange = this.handleChange.bind(this); this.handleSubmit = this.handleSubmit.bind(this); } handleChange(event) { this.setState({value: event.target.value}); } handleSubmit(event) { alert('提交的名字: ' + this.state.value); event.preventDefault(); } render() { return ( <form onSubmit={this.handleSubmit}> <label> 名字: <input type="text" value={this.state.value} onChange={this.handleChange} /> </label> <input type="submit" value="提交" /> </form> ); } }
在 React 中,数据是单向流动的。从示例中,咱们能看出来表单的数据源于组件的 state,并 经过 props 传入,这也称为单向数据绑定。而后,咱们又经过 onChange 事件处理器将新的表单数 据写回到组件的 state,完成了双向数据绑定。这也意味着咱们能够在执行最后 一步 setState 前,对表单值进行清洗和校验。react
React 受控组件更新 state 的流程:
(1)能够经过在初始 state 中设置表单的默认值。
(2)每当表单的值发生变化时,调用 onChange 事件处理器。
(3)事件处理器经过合成事件对象 e 拿到改变后的状态,并更新应用的 state。
(4)setState 触发视图的从新渲染,完成表单组件值的更新。this
若是一个表单组件没有 value props(单选按钮和复选框对应的是 checked prop) 时,就能够称为非受控组件。相应地,你能够使用 defaultValue 和 defaultChecked prop 来表示 组件的默认状态code
元素 | value属性 | change回调 | 回调获取新值 |
---|---|---|---|
<input type="text" /> |
value="string" | onChange | event.target.value |
<input type="checkbox" /> |
checked={boolean} | onChange | event.target.checked |
<input type="radio" /> |
checked={boolean} | onChange | event.target.checked |
<textarea /> |
value="string" | onChange | event.target.value |
<select /> |
value="option value" | onChange | event.target.value |
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" defaultValue="Bob" ref={this.input} /> </label> <input type="submit" value="Submit" /> </form> ); } }
受控组件和非受控组件各有优势,应该根据本身的具体需求选择受控仍是非受控component
特征 | 非受控 | 受控 |
---|---|---|
一次性取值(好比提交表单时) | ✅ | ✅ |
提交时验证 | ✅ | ✅ |
实时表单验证 | ❌ | ✅ |
有条件的禁用提交按钮 | ❌ | ✅ |
强制输入格式 | ❌ | ✅ |
一个数据有多个输入 | ❌ | ✅ |
动态输入 | ❌ | ✅ |