受控组件和非受控组件的区别

在 React 中,​受控组件(Controlled Components)​ 和 ​非受控组件(Uncontrolled Components)​ 是处理表单元素的两种不同方式,它们的核心区别在于 ​数据管理的方式 和 ​与 React 的交互模式。

受控组件(Controlled Components)

定义

表单元素(如 <input><textarea><select>)的值由 ​Reactstate 完全控制。用户输入会触发 React 的状态更新,表单的当前值始终与 Reactstate 同步。

关键特征

  • 数据流:单向绑定(从 React state 到 DOM)。
  • 更新方式:通过 onChange 事件手动更新 state。
  • 值的来源:组件的 value 或 checked 属性直接绑定到 state。

代码示例

import { useState } from 'react';function ControlledForm() {const [inputValue, setInputValue] = useState('');const handleChange = (e) => {setInputValue(e.target.value); // 手动同步到 state};return (<inputtype="text"value={inputValue} // 值由 React state 控制onChange={handleChange}/>);
}

适用场景

  • 需要实时验证输入(如密码强度检查)。
  • 动态表单(如根据输入内容显示其他字段)。
  • 强制输入格式(如只能输入数字)。

优点

  • 完全控制表单数据,确保 React state 是唯一数据源。
  • 支持复杂的交互逻辑(如输入时实时反馈)。

缺点

  • 代码量较多(需要为每个表单元素编写事件处理函数)。
  • 频繁的 state 更新可能导致性能问题(大型表单需优化)。

非受控组件(Uncontrolled Components)

定义

表单元素的值由 ​DOM 自身管理,React 通过 ref 在需要时(如表单提交时)直接读取 DOM 的值。用户输入不会触发 React 的状态更新。

关键特征

  • 数据流:直接操作 DOM。
  • 更新方式:通过 ref 手动获取值。
  • 值的来源:DOM 节点的当前值。

代码示例

import { useRef } from 'react';function UncontrolledForm() {const inputRef = useRef(null);const handleSubmit = (e) => {e.preventDefault();console.log(inputRef.current.value); // 通过 ref 获取 DOM 值};return (<form onSubmit={handleSubmit}><inputtype="text"ref={inputRef} // 使用 ref 关联 DOM 节点defaultValue="初始值" // 仅初始化时设置默认值/><button type="submit">提交</button></form>);
}

适用场景

  • 简单表单(不需要实时验证或动态交互)。
  • 文件上传(<input type="file"> 必须用非受控组件)。
  • 性能敏感场景(避免频繁 state 更新)。

优点

  • 代码简洁,无需管理状态。
  • 性能更好(减少渲染次数)。

缺点

  • 无法实时控制数据(如强制输入格式)。
  • 不符合 React 的“单一数据源”原则。

核心区别对比

特性受控组件非受控组件
数据管理React state 控制DOM 自身管理
值同步实时同步(onChange 事件)手动获取(通过 ref)
初始值设置通过 value 属性通过 defaultValue 属性
表单验证时机输入时实时验证提交时验证
代码复杂度较高(需处理事件和状态)较低(直接操作 DOM)
性能可能较低(频繁渲染)较高
React 哲学匹配度高(符合单向数据流)低(依赖 DOM 操作)

如何选择

  1. 优先受控组件:

大多数场景推荐使用受控组件,尤其是需要实时交互、验证或动态表单时。

  1. 非受控组件的合理场景:
  • 文件上传(<input type="file">)。
  • 性能敏感且无需实时反馈的表单。
  • 与非 React 的第三方库集成(如富文本编辑器)。

注意点

  1. 文件输入

<input type="file"> 必须用非受控组件,因为其值只能由用户设置(安全限制)。

  1. 默认值:

非受控组件用 defaultValuedefaultChecked 设置初始值(类似原生 HTML)。

  1. 受控组件的性能优化:

大型表单中避免频繁渲染,可通过防抖(debounce)或 useCallback 优化事件处理函数。

总结

  • ​受控组件:数据由 React 完全控制,适合复杂交互。
  • 非受控组件:数据由 DOM 管理,适合简单场景或性能敏感需求。

根据实际需求选择,优先遵循 React 的单向数据流原则,仅在必要时使用非受控组件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/74213.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

迈向云原生:理想汽车 OLAP 引擎变革之路

在如今数据驱动的时代&#xff0c;高效的分析引擎对企业至关重要。理想汽车作为智能电动汽车的领军企业&#xff0c;面临着海量数据分析的挑战。本文将展开介绍理想汽车 OLAP 引擎从存算一体向云原生架构演进的变革历程&#xff0c;以及在此过程中面临的挑战&#xff0c;以及是…

ZLMediaKit 源码分析——[3] ZLToolKit 中EventPoller之网络事件处理

系列文章目录 第一篇 基于SRS 的 WebRTC 环境搭建 第二篇 基于SRS 实现RTSP接入与WebRTC播放 第三篇 centos下基于ZLMediaKit 的WebRTC 环境搭建 第四篇 WebRTC学习一&#xff1a;获取音频和视频设备 第五篇 WebRTC学习二&#xff1a;WebRTC音视频数据采集 第六篇 WebRTC学习三…

【分布式】分布式限流方案解析

文章目录 固定窗口限流方案​实现方式​优点​缺点​ 滑动窗口限流方案​实现方式​优点​缺点​ 令牌桶限流方案​实现方式​优点​缺点​ 漏斗限流方案​实现方式​优点​缺点​ 在分布式系统蓬勃发展的当下&#xff0c;系统面临的流量挑战日益复杂。为确保系统在高并发场景下…

WPS JS宏编程教程(从基础到进阶)-- 第三部分:JS宏编程语言开发基础

第三部分:JS宏编程语言开发基础 @[TOC](第三部分:JS宏编程语言开发基础)**第三部分:JS宏编程语言开发基础**1. 变量与数据类型**变量声明:三种方式****示例代码****数据类型判断****实战:动态处理单元格类型**2. 运算符全解析**算术运算符****易错点:字符串拼接 vs 数值相…

Python - 爬虫-网页抓取数据-库urllib

urllib库是Python内置的HTTP请求库。无需额外安装&#xff0c;可以直接使用。urllib库包含以下四个模块。 urllib.request - 打开和读取 URL。urllib.error - 包含 urllib.request 抛出的异常。urllib.parse - 解析 URL。urllib.robotparser - 解析 robots.txt 文件。 1、reque…

C++进阶知识复习 1~15

C 进阶总复习 &#xff08;1~15&#xff09; 目的1. 介绍下程序从编写到可执行的整个过程2. C中的auto和decltype的区别3. 介绍下多态的实现原理4. C中的new[] 和delete[] 为什么一定要配对使用&#xff1f;5. C中malloc申请的内存 可以使用delete释放嘛6. 什么情况下会出现内存…

输电线路航空标志球:低空飞行的安全路标 / 恒峰智慧科技

在现代社会&#xff0c;随着航空业的快速发展&#xff0c;低空飞行活动日益频繁。为了确保飞行安全&#xff0c;避免飞机与高压电线等障碍物发生碰撞&#xff0c;输电线路航空标志球应运而生。这种装置被广泛应用于高压输电线路上&#xff0c;尤其是超高压和跨江输电线&#xf…

Debian/Ubuntu的networking的`/etc/network/interfaces`配置文件详解

Debian/Ubuntu的networking的/etc/network/interfaces配置文件详解 Debian/Ubuntu 的 /etc/network/interfaces 配置文件详解 在 Debian/Ubuntu 系统中&#xff0c;/etc/network/interfaces 是传统网络接口配置文件&#xff0c;用于定义网络接口的静态/动态配置。以下是逐项解…

OpenCV 图形API(或称G-API)(1)

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 引言 OpenCV 图形API&#xff08;或称G-API&#xff09;是一个新的OpenCV模块&#xff0c;旨在使常规图像处理更快且更便携。通过引入一种新的基于图的执行…

Leetcode 3505. Minimum Operations to Make Elements Within K Subarrays Equal

Leetcode 3505. Minimum Operations to Make Elements Within K Subarrays Equal 1. 解题思路2. 代码实现 题目链接&#xff1a;3505. Minimum Operations to Make Elements Within K Subarrays Equal 1. 解题思路 这一题大的思路上不难想到就是一个动态规划的思路。我们分别…

win10之mysql server 8.0.41安装

一 mysql server 下载 官网下载地址页面 https://dev.mysql.com/downloads/mysql/二 免装版使用步骤 1 解压 下载完成后,解压文件夹,如下所示: 2 执行安装命令 D:\soft\mysql\mysql-8.0.41-winx64\mysql-8.0.41-winx64\bin>mysqld --install Service successfully in…

第十二届蓝桥杯省赛软件类(cc++组)

第一题&#xff08;空间&#xff09; 解题思路 答案 #include <stdio.h>int main() {// 计算256MB对应的字节数&#xff0c;1MB 1024KB&#xff0c;1KB 1024Blong long total_bytes 256 * 1024 * 1024; // 每个32位二进制整数占4个字节&#xff08;32 / 8 4&#xf…

C++ 新特性 | C++ 11 | 移动语义

文章目录 一、移动语义1、为什么需要移动语义&#xff1f;2、怎么“偷”&#xff1f;——右值引用&#xff08;&&&#xff09;3、如何实现移动语义&#xff1f;——移动构造函数/赋值4、什么时候触发移动&#xff1f;5、移动 vs 拷贝 一、移动语义 1、为什么需要移动语…

wsl下ubuntu安装宝塔

在 WSL (Windows Subsystem for Linux) 下的 Ubuntu 中安装宝塔面板的步骤如下&#xff1a; 1. 确保 WSL 环境正常 已安装 WSL 2 并启用 Ubuntu 发行版&#xff08;推荐 Ubuntu 20.04/22.04&#xff09;。 在 PowerShell 中检查 WSL 版本&#xff1a; wsl --list --verbose 如…

UDP网络通信

UDP网络通信&#xff1a; 步骤1 创建套接字&#xff1a; #include <sys/types.h> #include <sys/socket.h>int socket(int domain, int type, int protocol);参数一 domain&#xff1a; AF_UNIX Local communication unix(7) 本地通信 AF_INET IPv4 Inte…

教你快速理解linux中的NUMA节点探测是干什么用的?

想象一个大城市被划分成几个区&#xff08;比如东区、西区&#xff09;。每个区有自己的超市&#xff08;内存&#xff09;&#xff0c;居民&#xff08;CPU&#xff09;去本区的超市买东西最快&#xff0c;去其他区的超市会慢一些。 NUMA节点探测&#xff0c;就是Linux系统在…

使用 Less 实现 PC 和移动端样式适配

&#x1f310; 使用 Less 实现 PC 和移动端样式适配 —— 以 position 属性为例 在前端开发中&#xff0c;我们常常会遇到这样一个场景&#xff1a; 在 PC 页面中需要某个元素是 position: relative;&#xff0c;但在移动端却希望它是 position: inherit;&#xff0c;以便更灵…

企业战略管理(设计与工程师类)-2-战略规划及管理过程-1-概述

战略管理过程 参考资料&#xff1a; 战略管理 - 清华大学- 蔡临宁公司战略与风险管理 - 华中科技大学 - 贺远琼战略管理 - 北京理工大学 - 杨万荣DeepSeek - 深度思考与联网检索 AFI框架 战略管理最典型的就是采用传统的AFI通用战略管理框架&#xff08;模型&#xff09;&a…

Swoole 的 Hyperf 框架和 Go 的 Gin 框架高并发原理以及技术实现对比分析

Swoole 的 Hyperf 框架和 Go 的 Gin 框架虽然都支持高并发&#xff0c;但它们的实现原理、底层机制和适用场景有显著差异。以下从 高并发原理、技术实现区别、优缺点 三个方面详细分析&#xff1a; 一、高并发实现原理 1. Hyperf (PHP Swoole) Hyperf 的高并发能力基于 Swoo…

【教程】如何利用bbbrisk一步一步实现评分卡

利用bbbrisk一步一步实现评分卡 一、什么是评分卡1.1.什么是评分卡1.2.评分卡有哪些 二、评分卡怎么弄出来的2.1.如何制作评分卡2.2.制作评分卡的流程 三、变量的分箱3.1.数据介绍3.2.变量自动分箱3.3.变量的筛选 四、构建评分卡4.1.评分卡实现代码4.2.评分卡表4.3.阈值表与分数…