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

React:受控组件和非受控组件

受控组件和非受控组件

      • 受控组件
      • 非受控组件
      • 选择建议

受控和非受控指的都是 state,也就是指受 state 控制、不受 state 控制

受控组件

对于 input 输入框,如果使用 value 属性来接受状态值,并且配置 onChange 事件,那它就是受控组件,也就是受 state 控制,因此,它不能直接编辑(在 input 中就是无法直接更改输入框中的值)

function ControlledInput() {const [value, setValue] = useState('');return <input value={value} onChange={(e) => setValue(e.target.value)} />;
}

受控组件的数据流是双向的。在上面这个例子中,往输入框输入内容,会即时反映到视图上。我们会发现它跟 Vue 中的 v-model 有相似之处

要获取组件的值,直接使用 state 的值就可以了

以下是官方的定义

受控组件是指表单元素的值由 React 组件的状态(state)控制。用户输入时,值会通过事件处理函数更新状态,从而实现双向数据绑定受控组件的值始终与 React 的状态同步,适用于需要对输入进行实时验证或处理的场景。

优点包括数据流清晰、易于验证和动态控制。缺点是代码量较多,尤其是表单复杂时,需要为每个输入字段编写事件处理逻辑。


非受控组件

当我们在 input 标签中使用 defaultValue 属性进行赋值时,那它就是非受控组件。与受控组件相反,非受控组件可以直接编辑组件的值

要获取非受控组件的值,需要通过 ref,也可以通过 getElementsById 来获取

非受控组件的值由 DOM 自身管理,而不是通过 React 状态控制。通常通过 ref 直接访问 DOM 元素的值,适用于简单表单或需要集成第三方库的场景。

<inputtype="text"defaultValue="初始值"ref={(input) => this.input = input}
/>
import React, { Component } from 'react';export class UnControll extends Component {constructor(props) {super(props);this.inputRef = React.createRef();}handleSubmit() {console.log(this.inputRef.current.value);}render() {return (<form onSubmit={(e) => this.handleSubmit(e)}><input defaultValue="123" ref={this.inputRef} /></form>)}
}

优点包括代码简洁、性能较高,适合无需即时反馈的场景。缺点是数据流不够透明,难以实现复杂的交互逻辑。

选择建议

需要实时验证或动态控制表单行为时,优先使用受控组件。
对于简单表单或性能敏感场景,非受控组件更为合适。两者可以结合使用,例如在表单提交时通过 ref 获取非受控组件的值。

http://www.lryc.cn/news/611798.html

相关文章:

  • WebStorm转VSCode:高效迁移指南
  • 前端开发_怎么禁止用户复制内容
  • vue3 el-dialog自定义实现拖拽、限制视口范围增加了拖拽位置持久化的功能
  • 【前端开发】三. JS运算符
  • 2.6 sync
  • vue3 find 数组查找方法
  • JSON巴巴 - 专业JSON格式化工具:让任何JSON都能完美格式化
  • Excel将整列值转换为字符串
  • Git 乱码文件处理全流程指南
  • 通过最严时序标准,再登产业图谱榜首,TDengine 时序数据库在可信数据库大会荣获双荣誉
  • Apache Flink 的详细介绍
  • 时序数据库的发展现状与未来趋势
  • Excel单元格设置下拉框、选项背景
  • 【OSCP】- Monitoring 靶场学习(Proving Grounds Play)
  • SpringBoot 整合Langchain4j 对接主流大模型实战详解
  • 科技云报到:Agent应用爆发,谁成为向上托举的力量?
  • 第一章-网络信息安全概述
  • 数据赋能(381)——数据挖掘——支持异类数据库
  • C语言的数组与字符串练习题2
  • GitHub 趋势日报 (2025年08月05日)
  • Gitlab+Jenkins+K8S+Registry 建立 CI/CD 流水线
  • 8.6 CSS3rem布局
  • npm scripts 使用指南
  • 解决在IDEA、webstorm里Git特别慢的问题
  • 自动驾驶系统的网络安全风险分析
  • vasp计算弹性常数
  • MyBatis核心配置深度解析:从XML到映射的完整技术指南
  • 构建语义搜索引擎:Weaviate的实践与探索
  • 实名认证 —— 腾讯云人脸识别接口
  • Redis集群核心原理与实战解析