标签:label 渲染 inpu sel 集成 render his was 要求
在大多数情况下,推荐使用受控组件来实现表单。在受控组件中,表单数据由 React 组件负责处理。另外一个选择是不受控组件,其表单数据由 DOM 元素本身处理。
要编写一个未控制组件,你可以使用一个 ref 来从 DOM 获得 表单值,而不是为每个状态更新编写一个事件处理程序。
例如,在不受控组件中,以下代码接受一个单独的名字 :
1 class NameForm extends React.Component { 2 constructor(props) { 3 super(props); 4 this.handleSubmit = this.handleSubmit.bind(this); 5 } 6 7 handleSubmit(event) { 8 alert(‘A name was submitted: ‘ + this.input.value); 9 event.preventDefault(); 10 } 11 12 render() { 13 return ( 14 <form onSubmit={this.handleSubmit}> 15 <label> 16 Name: 17 <input type="text" ref={(input) => this.input = input} /> 18 </label> 19 <input type="submit" value="Submit" /> 20 </form> 21 ); 22 } 23 }
因为不受控组件的数据来源是 DOM 元素,当使用不受控组件时很容易实现 React 代码与非 React 代码的集成。如果你希望的是快速开发、不要求代码质量,不受控组件可以一定程度上减少代码量。否则。你应该使用受控组件。
在 React 渲染生命周期中,表单元素中的 value
属性将会覆盖 DOM 中的 value 。在不受控组件中,你可能希望 React 有初始值,但保留后续更新不受控制。在这种情况下,你需要使用 defaultValue
属性而不是 value
属性。
1 render() { 2 return ( 3 <form onSubmit={this.handleSubmit}> 4 <label> 5 Name: 6 <input 7 defaultValue="Bob" 8 type="text" 9 ref={(input) => this.input = input} /> 10 </label> 11 <input type="submit" value="Submit" /> 12 </form> 13 ); 14 }
同样, <input type="checkbox">
和 <input type="radio">
支持 defaultChecked
,而 <select>
和 <textarea>
支持 defaultValue
。
使用value和defaultValue的区别是value的值不能改变,defaultValue的值可以改变。
标签:label 渲染 inpu sel 集成 render his was 要求
原文地址:https://www.cnblogs.com/cangqinglang/p/9078381.html