zoukankan      html  css  js  c++  java
  • 不受控组件

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

  • 相关阅读:
    MultipartFile 多文件上传的应用
    启动关闭zookeeper集群的脚本
    分布式锁
    NFS部署教程
    Docker安装(Debian8)-构建简单的SpringBoot应用
    Nginx实战-后端应用健康检查
    分布式文件系统FastDFS安装教程
    Redis缓存使用技巧
    WebSocket原理与实践
    HashMap中ConcurrentModificationException异常解读
  • 原文地址:https://www.cnblogs.com/cangqinglang/p/9078381.html
Copyright © 2011-2022 走看看