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

react 受控组件和非受控组件

在 React 中,受控组件和非受控组件是两种处理表单元素(如输入框、选择框等)值的方式。

1. 受控组件

受控组件是指 React 组件的表单元素的值是由 React 组件的 state 来管理的。换句话说,React 会全程控制表单元素的值,每当输入框的内容发生变化时,都会触发事件(如 onChange),并更新组件的 state,从而使组件重新渲染。

特点:

  • 表单的值由 React 的 state 控制。
  • 必须通过 state 和 setState 来读取和修改表单元素的值。
  • 更容易实现表单验证和其他交互逻辑。

示例:

import React, { useState } from 'react';

function ControlledInput() {
  const [value, setValue] = useState('');

  const handleChange = (e) => {
    setValue(e.target.value);  // 更新 state
  };

  return (
    <input
      type="text"
      value={value}          // 由 state 控制值
      onChange={handleChange} // 更新 state
    />
  );

}

2. 非受控组件(Uncontrolled Component)

非受控组件是指表单元素的值不受 React state 的控制,而是通过 DOM 元素的本地状态来处理。这意味着 React 不会直接管理表单元素的值,值的管理交由 DOM 本身来控制。

特点:

  • 表单的值由 DOM 控制,而非 React state。
  • 可以通过 ref 获取当前表单元素的值,而不需要设置 value 和 onChange 处理事件。
  • 更接近传统的 HTML 表单操作方式,适合简单场景。

示例:

import React, { useRef } from 'react';

function UncontrolledInput() {
  const inputRef = useRef(null);

  const handleSubmit = (e) => {
    e.preventDefault();
    alert('输入的值是: ' + inputRef.current.value); // 使用 ref 获取值
  };

  return (
    <form onSubmit={handleSubmit}>
      <input type="text" ref={inputRef} />  {/* 不需要 value 和 onChange */}
      <button type="submit">提交</button>
    </form>
  );
}

总结:

  • 受控组件适用于复杂的交互场景(如表单验证、动态表单等),可以让 React 完全控制表单的行为。
  • 非受控组件适用于简单场景,尤其是当表单不需要频繁的与 React 的 state 交互时。

http://www.kler.cn/a/395319.html

相关文章:

  • H.265流媒体播放器EasyPlayer.js H.264/H.265播放器chrome无法访问更私有的地址是什么原因
  • mysql每日一题(上升的温度,date数据的计算)
  • 3588 yolov8 onnx 量化转 rknn 并运行
  • 深度学习之pytorch常见的学习率绘制
  • 《Python Web 抓取实战:豆瓣电影 Top 250 数据抓取与分析》
  • 图论-代码随想录刷题记录[JAVA]
  • 使用git命令实现对gitee仓库的下载、更新、上传、上传更新操作。
  • FluentUI使用
  • kafka 生产经验——数据积压(消费者如何提高吞吐量)
  • 图像处理技术椒盐噪声
  • [C++刷题] 基础小知识点(5) 数字反转\求数字位数
  • Vue2:脚手架 vue-cli
  • UDP/TCP 简述
  • Elasticsearch集群和Kibana部署流程
  • 【OceanBase 诊断调优】—— OceanBase 数据库统计信息被禁用,状态为 broken 的原因和解决方法
  • 【论文阅读】Virtual Compiler Is All You Need For Assembly Code Search
  • 数位DP学习
  • 人工智能:重塑医疗、企业与生活的未来知识管理——以HelpLook为例
  • 【数字图像处理+MATLAB】基于 Sobel 算子计算图像梯度并进行边缘增强:使用 imgradientxy 函数
  • 《Java核心技术 卷I》Swing处理2D图形
  • 探索 Python HTTP 的瑞士军刀:Requests 库
  • JavaScript逆向爬虫教程-------基础篇之深入JavaScript运行原理以及内存管理
  • openwebui二改界面环境搭建
  • Ubuntu网络(prot)连通性检测
  • 当使用key-value方式进行参数传递时,若key对应的是一个对象或数组结构,如何利用API Post工具进行模拟操作。
  • thinkphp6 --数据库操作 增删改查