IT序号网

不受控组件

leader 2021年05月25日 编程语言 292 0

在大多数情况下,推荐使用受控组件来实现表单。在受控组件中,表单数据由 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的值可以改变。


评论关闭
IT序号网

微信公众号号:IT虾米 (左侧二维码扫一扫)欢迎添加!

Refs 和 DOM