我是靠谱客的博主 怕黑发箍,最近开发中收集的这篇文章主要介绍react受控组件是什么,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

react受控组件是什么

渲染表单的 React 组件还控制着用户输入过程中表单发生的操作。被 React 以这种方式控制取值的表单输入元素就叫做“受控组件”。

有网友这样解释:在React中,每当表单的状态发生变化时,都会被写入到组件的state中,这种组件在React被称为受控组件。

受控组件的更新流程:

  • 1,可以通过在初始state中设置表单的默认值

  • 2,每当表单的值发生变化时,调用onChange事件处理器,

  • 3,事件处理器通过事件对象e拿到改变后的状态,改变state;

  • 4,setState触发视图更新,完成表单组件值的更新

受控组件是通过通过回调函数来更新当前值,譬如 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} />;
}
登录后复制

扩展知识:

什么是不受控组件?

不受控组件则是内部存储自身状态的组件,可以使用 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 。

对于受控组件,我们可以在输入时进行验证,但对于不受控组件则不能进行验证。

【相关推荐:javascript视频教程、web前端】

以上就是react受控组件是什么的详细内容,更多请关注靠谱客其它相关文章!

最后

以上就是怕黑发箍为你收集整理的react受控组件是什么的全部内容,希望文章能够帮你解决react受控组件是什么所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(75)

评论列表共有 0 条评论

立即
投稿
返回
顶部