react受控组件和非受控组件(此外也称约束组件)

React 中的受控组件和非受控组件是指表单元素(如 input、textarea、select 等)的两种不同管理方式。它们之间的主要区别在于状态的管理方式。

受控组件(Controlled Components)

1、受控组件通过 React 组件的状态(state)来管理表单元素的值。

2、当用户与表单元素交互时,触发事件(如 onChange),更新 React 组件的状态,进而更新表单元素的值。

3、通过 React 组件的状态来控制表单元素的值,从而实现数据的双向绑定。

javascript 复制代码
const [value, setValue] = useState('');

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

return (
  <input type="text" value={value} onChange={handleChange} />
);

非受控组件(Uncontrolled Components)

1、非受控组件中,表单元素的值由 DOM 元素本身来管理,而不受 React 组件的状态控制。

2、通常通过 ref 来获取表单元素的值,而不需要通过 React 组件的状态来管理。

3、开发者需要手动处理表单元素的值,无法利用 React 的状态自动管理表单元素的值。

javascript 复制代码
const inputRef = useRef(null);

const handleClick = () => {
  const value = inputRef.current.value;
  // 处理表单元素的值
};

return (
  <input type="text" ref={inputRef} />
  <button onClick={handleClick}>Submit</button>
);

选择使用受控组件还是非受控组件取决于具体的需求和开发场景。通常情况下,推荐使用受控组件,因为它更符合 React 的单向数据流模型,便于状态管理和数据流控制。但在一些特定情况下,非受控组件也可以提供更简洁的解决方案。

相关推荐
RPGMZ1 分钟前
RPGMZ游戏引擎事件技巧大全
javascript·游戏引擎·事件·rpgmz·rpgmakermz
一天 24h2 分钟前
从单体到分布式:JWT 如何彻底改变 Web 认证系统
前端·分布式
持梦远方3 分钟前
Nginx 静态资源挂载与前端部署实战笔记
linux·前端·笔记·nginx
木斯佳4 分钟前
前端八股文面经大全:腾讯云智前端一面(2026-05-13)·面经深度解析
前端·状态模式
fanzhonghong5 分钟前
javaWeb后端开发之Linux项目部署3和Docker部署1
linux·服务器·前端·docker
拉里呱唧6 分钟前
在线可视化HTML编辑器横评:8款拖拽式工具的实测对比
前端·编辑器·html
贵州晓智信息科技6 分钟前
曼德勃罗集的 Three.js 实现
开发语言·javascript·ecmascript
lihaozecq9 分钟前
Agent 开发 Todo 机制设计,让 Agent 拥有规划能力
前端·agent·ai编程
lchcy18 分钟前
移动端h5好多兼容性问题啊
前端
KaMeidebaby23 分钟前
卡梅德生物技术快报|多肽库筛选:基于全质粒 PCR 的噬菌体文库构建与小分子表位淘选实战
前端·数据库·其他·百度·新浪微博