React | 受控组件(Controlled Component)与不受控组件(Uncontrolled Component)的区别

1 概述

如果碰到下面的警告,你将如何处理呢?
在这里插入图片描述
我们在使用 React 时,处理文件经常会碰到这个警告。这个警告与有状态 DOM 组件(譬如,表单元素)有关。

2 什么是受控组件?

受控组件是通过通过回调函数来更新当前值,譬如 OnChange。父组件则通过回调函数控制并管理它的状态并将新值作为属性传给它。受控组件也称为“哑巴组件”。

const { useState } from 'react';

function Controlled () {
  const [email, setEmail] = useState();

  const handleInput = (e) => setEmail(e.target.value);


  return <input type="text" value={email} onChange={handleInput} />;
}

3 什么是不受控组件?

不受控组件则是内部存储自身状态的组件,可以使用 ref 查询 DOM,以便在需要时查找其当前值。有点像传统的 HTML。大多数原生的 React 表单组件都支持受控和不受控:

const { useRef } from 'react';

function Example () {
  const inputRef = useRef(null);
  return <input type="text" defaultValue="bar" ref={inputRef} />
} 

4 它们之间有什么区别?

  • 在受控组件中,表单数据由 React 组件处理。而在不受控组件中,表单数据由 DOM 本身处理。
  • 对于受控组件,必须使用组件状态。对于不受控制的组件,状态的使用是完全可选的,但必须在其中使用 Refs
  • 对于受控组件,我们可以在输入时进行验证,但对于不受控组件则不能进行验证。

5 总结

如果你在做一个大型项目,所有的输入组件都已经作为公共组件创建,为了保持应用程序之间的一致性,那么最好使用受控组件。如果是小型项目,不需要在运行时更改事件操作,那么使用不受控组件将易于管理。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

孟华328

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值