当前位置: 首页 > news >正文

【React】React表单组件

        在React中,表单组件是用来处理用户输入的重要部分。React提供了多种方式来处理表单,包括受控组件(Controlled Components)和非受控组件(Uncontrolled Components)。同时,表单组件也涉及到一些交互属性,这些属性使得表单元素能够响应用户的操作。   

交互属性


交互属性是指那些能够响应用户操作并触发事件的属性。在表单组件中,常见的交互属性包括:

onChange: 当表单元素的值发生变化时触发。
onBlur: 当表单元素失去焦点时触发。
onFocus: 当表单元素获得焦点时触发。
onClick: 当表单元素被点击时触发。
onSubmit: 当表单提交时触发。
这些属性通常与事件处理函数一起使用,以便在用户与表单元素交互时执行特定的操作。

受控组件(Controlled Components)


       受控组件是那些其值由React组件的状态控制的表单元素。受控组件的特点是它们的值总是与组件的状态保持同步。当用户与表单元素交互时,事件处理函数会更新组件的状态,从而更新表单元素的值。

以下是一个受控组件的示例:


import React, { useState } from 'react';  
  
function ControlledInput() {  
  const [inputValue, setInputValue] = useState('');  
  
  const handleChange = (event) => {  
    setInputValue(event.target.value);  
  };  
  
  return (  
    <form>  
      <label>  
        输入值:  
        <input type="text" value={inputValue} onChange={handleChange} />  
      </label>  
      <button type="submit">提交</button>  
    </form>  
  );  
}
       在这个例子中,input元素的值通过value属性与组件的状态inputValue绑定。当用户在输入框中输入文本时,handleChange函数会被调用,更新组件的状态,从而保持输入框的值与状态同步。


非受控组件(Uncontrolled Components)


        非受控组件的值不由React组件的状态直接控制,而是由DOM管理。非受控组件的值不会反映到组件的状态中,除非你显式地从DOM中读取它们。这通常通过引用(refs)来实现。

        非受控组件通常更简单,因为你不需要为每个表单元素编写状态更新逻辑。但是,它们也不那么灵活,特别是当你需要实时跟踪表单状态或进行复杂验证时。

以下是一个非受控组件的示例:


import React, { useRef } from 'react';  
  
function UncontrolledInput() {  
  const inputRef = useRef(null);  
  
  const handleSubmit = (event) => {  
    event.preventDefault();  
    const inputValue = inputRef.current.value;  
    // 处理inputValue...  
  };  
  
  return (  
    <form onSubmit={handleSubmit}>  
      <label>  
        输入值:  
        <input type="text" ref={inputRef} />  
      </label>  
      <button type="submit">提交</button>  
    </form>  
  );  
}
       在这个例子中,我们使用useRef创建了一个ref,并将其附加到input元素上。当用户提交表单时,我们通过inputRef.current.value从DOM中读取输入框的值。


       React表单组件通过交互属性响应用户操作,并通过受控组件和非受控组件两种模式管理表单数据。受控组件提供了更大的灵活性和控制力,但可能需要更多的代码来维护状态。非受控组件更简单,但可能不适合所有场景。在选择使用哪种模式时,应根据你的具体需求和项目的复杂性进行权衡。

相关文章:

  • Android裁剪图片为波浪形或者曲线形的ImageView
  • C++就业方向
  • Vue——案例01(查询用户)
  • c语言中动态内存管理
  • go中函数与方法的区别与go中关于面向对象理解
  • Bun安装与使用
  • Vant Weapp小程序 van-uploader 文件上传点击无反应,删除无反应
  • Android Q(10)黑暗模式适配的实现
  • A Little Is Enough: Circumventing Defenses For Distributed Learning
  • HTML——1.简介、基础、元素
  • 封装性练习
  • react native hooks 页面出现重绘问题,如何解决
  • 机器视觉系列之【硬件知识】-光源(三)
  • HTML网站的概念
  • 【常见面试题】Golang中,协程数最多可以开多少个?
  • JavaScript 如何正确处理 Unicode 编码问题!
  • Android Studio:GIT提交项目到远程仓库
  • Angular 4.x 动态创建组件
  • Git学习与使用心得(1)—— 初始化
  • go append函数以及写入
  • Golang-长连接-状态推送
  • IIS 10 PHP CGI 设置 PHP_INI_SCAN_DIR
  • iOS帅气加载动画、通知视图、红包助手、引导页、导航栏、朋友圈、小游戏等效果源码...
  • MySQL用户中的%到底包不包括localhost?
  • Rancher如何对接Ceph-RBD块存储
  • React-redux的原理以及使用
  • Vue全家桶实现一个Web App
  • 编写高质量JavaScript代码之并发
  • 程序员该如何有效的找工作?
  • 多线程 start 和 run 方法到底有什么区别?
  • 工作中总结前端开发流程--vue项目
  • 基于Mobx的多页面小程序的全局共享状态管理实践
  • 深入 Nginx 之配置篇
  • 小程序、APP Store 需要的 SSL 证书是个什么东西?
  • 小程序01:wepy框架整合iview webapp UI
  • 小程序开发之路(一)
  • 一个普通的 5 年iOS开发者的自我总结,以及5年开发经历和感想!
  • 优秀架构师必须掌握的架构思维
  • 06-01 点餐小程序前台界面搭建
  • const的用法,特别是用在函数前面与后面的区别
  • 宾利慕尚创始人典藏版国内首秀,2025年前实现全系车型电动化 | 2019上海车展 ...
  • 基于django的视频点播网站开发-step3-注册登录功能 ...
  • ​渐进式Web应用PWA的未来
  • #Linux(帮助手册)
  • #传输# #传输数据判断#
  • (17)Hive ——MR任务的map与reduce个数由什么决定?
  • (附源码)ssm捐赠救助系统 毕业设计 060945
  • .htaccess 强制https 单独排除某个目录
  • .NET Core 中插件式开发实现
  • .Net FrameWork总结
  • .NET 使用配置文件
  • .NET/C# 使用 SpanT 为字符串处理提升性能
  • .NET6使用MiniExcel根据数据源横向导出头部标题及数据
  • @RequestBody与@ResponseBody的使用
  • [ vulhub漏洞复现篇 ] Django SQL注入漏洞复现 CVE-2021-35042