当前位置: 首页 > 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.dtcms.com/a/318118.html

相关文章:

  • 将ssm聚合项目部署到云服务器上
  • MyBatis基础操作完整指南
  • 计数组合学7.14(对偶 RSK 算法)
  • 四、Envoy动态配置
  • 工业协议转换终极武器:EtherCAT转PROFINET网关的连接举例
  • 直播SDK商业化 vs 开源路线:工程稳定性、成本与演进能力全对比
  • 嵌入式开发学习———Linux环境下IO进程线程学习(五)
  • Flink CDC如何保障数据的一致性?
  • 云计算一阶段Ⅱ——12. SELinux 加固 Linux 安全
  • Dart语言“跨界”指南:从JavaScript到Kotlin,如何用多语言思维快速上手
  • Pipeline功能实现Redis批处理(项目批量查询点赞情况的应用)
  • Typescript入门-类型讲解
  • django object.create之后返回id
  • 【音视频】ALSA详细介绍
  • 从单枪匹马到联盟共生:白钰玮的IP破局之路​
  • 最新windows安装git(保姆及教程)
  • Python 高阶函数:用函数玩出花样
  • gpt-oss openai开源大模型
  • MCP 协议:AI 时代的 “万能转接头”,从 “手动粘贴” 到 “万能接口”:MCP 协议如何重构 AI 工具调用规则?
  • C++11之智能指针
  • springboot项目justAuth扩展第二个小程序
  • clock_adjtime、clock_getres、clock_gettime、 clock_nanosleep、clock_settime 系统调用及示例
  • 【面试八股总结】线程/进程同步问题
  • 概率/期望 DP Let‘s Play Osu!
  • 【数论】素数
  • Vue3入门到精通: 1.2 Vue3响应式系统深度解析
  • go与grpc
  • 网站、域名、IP在什么场景下需要备案
  • Linux之Shell脚本基本语法
  • InfluxDB 集群部署与高可用方案(二)