0

0

理解React中受控和不受控制的组件

花韻仙語

花韻仙語

发布时间:2025-01-31 20:44:01

|

813人浏览过

|

来源于php中文网

原创

理解react中受控和不受控制的组件

React开发中,选择受控组件还是非受控组件是构建表单时的关键决策。两者各有优劣,理解其差异对高效开发至关重要。本文将深入探讨它们的定义、区别、优势以及各自的适用场景。

什么是受控组件?

在React中,受控组件是指其值由React组件状态管理的表单元素。这意味着组件状态存储当前值,并在用户交互时更新状态。

受控组件示例:

import React, { useState } from 'react';

const ControlledComponent = () => {
  const [inputValue, setInputValue] = useState('');

  const handleChange = (event) => {
    setInputValue(event.target.value);
  };

  const handleSubmit = (event) => {
    event.preventDefault();
    alert(`提交的值: ${inputValue}`);
  };

  return (
    
); }; export default ControlledComponent;

此例中,输入字段的值由inputValue状态控制。用户输入时,handleChange函数更新状态。

什么是非受控组件?

非受控组件则自行管理内部状态,不依赖React的状态管理机制,而是使用DOM处理表单数据。输入值不存储在组件状态中,但可通过ref访问。

非受控组件示例:

osCommerce
osCommerce

osCommerce 是一套基于GNU GPL授权的开源在线购物电子商务解决方案。osc具有易于操作的可视化安装界面、完善的前台商品展示和户在线购物车功能、强大的后台管理,还有运行速度快,国外很受推崇。官方并没有提供中文语言包,只能靠国内的一个组织汉化,可定制性相对差。

下载
import React, { useRef } from 'react';

const UncontrolledComponent = () => {
  const inputRef = useRef(null);

  const handleSubmit = (event) => {
    event.preventDefault();
    alert(`提交的值: ${inputRef.current.value}`);
  };

  return (
    
); }; export default UncontrolledComponent;

此例中,输入字段的值通过ref (inputRef) 直接从DOM获取。组件不维护输入值的自身状态。

何时使用哪种类型?

  • 受控组件: 适用于需要根据用户输入管理复杂表单、实现验证或需要动态行为的场景。当需保持表单数据与组件状态同步时,也是首选。

  • 非受控组件: 适用于简单表单,或希望快速原型而无需状态管理开销的场景。与不依赖React状态管理的库集成时也很有用。

结论

React中的受控组件由React状态控制表单元素的值,允许完全控制表单数据,便于实时管理、验证和操作输入值。但需要更多样板代码,大型表单时性能可能降低。

非受控组件则内部存储状态,仅在必要时(如表单提交)与之交互。它们易于实现,性能可能更好,尤其对于大型表单。但对表单数据的控制较少,动态验证或修改也更困难。

相关专题

更多
DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

3190

2024.08.14

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

31

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

119

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

180

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

16

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

70

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

63

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

64

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

光速学会docker容器
光速学会docker容器

共33课时 | 1.9万人学习

时间管理,自律给我自由
时间管理,自律给我自由

共5课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号