首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

带有React钩子的受控/非受控输入字段

基础概念

受控组件:在React中,受控组件是指其值由React状态管理的表单元素。这意味着每当用户与输入字段交互时,React都会更新其状态。

非受控组件:与受控组件相反,非受控组件的值由DOM自身管理。React不会控制其值,但可以通过ref来访问DOM元素的当前值。

React钩子:React钩子是React 16.8版本引入的新特性,允许你在不编写类的情况下使用状态和其他React特性。常用的钩子包括useStateuseRef

优势

受控组件

  1. 实时验证:可以在用户输入时立即进行验证。
  2. 更好的控制:React可以完全控制输入的值和行为。
  3. 易于集成:与表单的其他部分(如提交按钮)集成更容易。

非受控组件

  1. 简单性:不需要额外的状态管理,代码更简洁。
  2. 性能优化:对于简单的表单,非受控组件可能更快,因为不需要每次都更新React状态。

类型与应用场景

受控组件

  • 应用场景:复杂的表单、需要实时验证的表单、需要与后端数据同步的表单。
  • 示例:注册表单、登录表单、搜索框。

非受控组件

  • 应用场景:简单的表单、不需要实时验证的表单、只需要一次性获取值的表单。
  • 示例:搜索框(提交时获取值)、文件上传。

示例代码

受控组件

代码语言:txt
复制
import React, { useState } from 'react';

function ControlledInput() {
  const [value, setValue] = useState('');

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

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

export default ControlledInput;

非受控组件

代码语言:txt
复制
import React, { useRef } from 'react';

function UncontrolledInput() {
  const inputRef = useRef(null);

  const handleSubmit = (event) => {
    event.preventDefault();
    console.log(inputRef.current.value);
  };

  return (
    <form onSubmit={handleSubmit}>
      <input
        type="text"
        ref={inputRef}
      />
      <button type="submit">Submit</button>
    </form>
  );
}

export default UncontrolledInput;

常见问题及解决方法

问题1:受控组件的值不更新

原因:可能是onChange事件处理函数没有正确设置,或者状态更新函数没有正确调用。

解决方法: 确保onChange事件处理函数正确绑定,并且状态更新函数被正确调用。

代码语言:txt
复制
const handleChange = (event) => {
  setValue(event.target.value); // 确保这一行代码正确执行
};

问题2:非受控组件的值获取不到

原因:可能是ref没有正确设置,或者在提交表单时没有正确访问ref的值。

解决方法: 确保ref正确设置,并且在提交表单时正确访问ref的值。

代码语言:txt
复制
const inputRef = useRef(null);

const handleSubmit = (event) => {
  event.preventDefault();
  console.log(inputRef.current.value); // 确保这一行代码正确执行
};

通过以上方法,可以有效解决在使用React钩子时遇到的受控和非受控输入字段的相关问题。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • React受控组件和非受控组件

    在React中,可变状态通常保存在组件的状态属性中,并且只能使用 setState() 进行更新,而呈现表单的React组件也控制着在后续用户输入时该表单中发生的情况,以这种由React控制的输入表单元素而改变其值的方式...即不受setState()的控制,与传统的HTML表单输入相似,input输入值即显示最新值。 在非受控组件中,可以使用一个ref来从DOM获得表单值。...三、异同和使用场景 1、受控组件 受控组件依赖于状态 受控组件的修改会实时映射到状态值上,此时可以对输入的内容进行校验 受控组件只有继承React.Component才会有状态 受控组件必须要在表单上使用...onChange事件来绑定对应的事件 2、非受控组件 非受控组件不受状态的控制 非受控组件获取数据就是相当于操作DOM 非受控组件可以很容易和第三方组件结合,更容易同时集成 React 和非 React...2、非受控组件使用场景:一般用于无任何动态初始值信息的情况。例如:form表单创建信息时,input表单元素都没有初始值,需要用户输入的情况。

    3.7K10

    React 中的受控组件和非受控组件

    一些背景 如果初涉 React 应用开发,你可能曾嘀咕过:“受控组件和非受控组件是啥?”。那么我建议你额外花点时间先看看官网的文档。...在 React 应用中之所以需要受控组件和非受控组件,起因于、 和 这类特定的 DOM 元素默认在 DOM 层中维持状态(用户输入)。...受控组件用来在 React 中也保存该状态,比如同步到渲染输入元素的组件、树结构中的某个父组件,或者一个 flux store 中。 而这种模式可以被扩展至特定的非 DOM 状态相关的用例中。...React 中的 Inputs 对于 React 中的 Inputs,是这样工作的: 要创建一个非受控 input,要设置一个 defaultValue 属性。...关键在于创建一个组件接口,可以在两种可能的属性配置中选择其一。 要创建一个非受控组件,就将想控制的属性定义成 defaultXXX。

    2.7K20

    React非受控组件

    在React中,组件的状态(state)通常由组件自身管理和控制。然而,有时我们也可以使用非受控组件来处理表单元素或其他用户输入,这意味着我们不需要显式地管理和更新组件的状态。...非受控组件React中的非受控组件是指那些其值不由React的状态管理的组件。相反,它们依赖于底层的DOM元素来存储和管理数据。我们可以使用ref来访问和操作非受控组件的值。...以下是一个示例,展示了如何在React中创建一个非受控的输入组件:import React from 'react';class UncontrolledComponent extends React.Component...例如,当需要在表单提交时获取表单字段的值,并进行后续处理时,非受控组件是一个不错的选择。第三方库集成:有时我们可能需要与第三方库集成,这些库可能依赖于底层DOM元素来存储和管理数据。...注意事项虽然非受控组件提供了一种简单的方式来处理用户输入,但也需要注意以下事项:不受控制:非受控组件的值不受React状态管理,这意味着React无法对其进行验证、更新或重置。

    68320

    React 非受控组件

    非受控组件(Uncontrolled Components) 使用非受控组件 在大部分情况下,推荐使用 受控组件 来实现表单、输入框等状态控制。在受控组件中,表单等数据都有React组件自己处理。...这里将介绍另外一种非受控组件,表单的数据有Dom自己控制。 非受控组件实现的重点是用Refs特性获取真实Dom来代替每次数据变更去更新组件的状态值。...例如下面的代码,在非受控组件中记录被用户输入的名字: class NameForm extends React.Component { constructor(props) { super(...由于在非受控组件中使用Refs特性获取了真实Dom的实例,所以在使用非受控组建时,更容易集成React和非React代码,在某些时候也可以省略一些代码。但是建议除了特殊情况,都使用受控组件。...如果想要深入理解什么情况下使用哪种组件,建议阅读 受控和不受控表单输入 一文。 组件默认值 在React渲染的生命周期,表单中的value属性会被覆盖Dom中的value值。

    53820

    React 深度编程:受控组件与非受控组件

    作者:司徒正美 https://segmentfault.com/a/1190000012458996 受控组件与非受控组件在官网与国内网上的资料都不多,有些人觉得它可有可不有,也不在意。...譬如你只是做ListView这样简单的数据显示,将数据拍出来,那么for循坏与就足够了,但后台系统存在大量报表,不同的表单联动,缺了受控组件真的不行。 受控组件与非受控组件是React处理表单的入口。...我们再看非受控组件,既然value/checked已经被占用了,React启用了HTML中另一组被忽略的属性defaultValue/defaultChecked。...但非受控组件的出发点是忠实于用户操作,如果用户在代码中 以后 就再不生效,一直是xxxx。 它怎么做到这一点,怎么辨识这个修改是来自框架内部或外部呢?...不过,到这步,大家都明白,无论是官方react还是anu/qreact都是通过Object.defineProperty来控制用户的输入的。

    1.7K70

    我们应该如何优雅的处理 React 中受控与非受控

    受控 & 非受控 今天来和大家简单聊聊 React 中的受控和非受控的概念。...被 React 以这种方式控制取值的表单输入元素就叫做“受控组件”。 上述的描述来自 React 官方文档,其实受控的概念也非常简单。...之后当用户在页面上的 input 元素中输入任何值表单值都会跟随用户输入而实时变化而并不受任何组件状态的控制,这就被称为非受控组件。...重要区分点 上边我们聊到了 React 中的受控和非受控的概念,在 React 中区分受控组件和非受控组件有一个最重要的 point 。...只需要传入 defaultValue 的值就可以使用非受控状态的 input 。 受控处理 上述我们用非常简单的代码实现了非受控的 Input 输入框,此时我们再来看看如何兼顾受控状态的值。

    6.6K10

    React 中非受控和受控的组件

    该组件将返回带有事件的输入字段,该事件正在记录输入字段值,并使用该方法将名称设置为新的输入值。 对于受控组件来说,输入的值始终由 React 的 state 驱动。...然而当有多个输入框,或者多个这种组件时,如果想同时获取到全部的值就必须每个都要编写事件处理函数,这会让代码看着很臃肿,所以为了解决这种情况,出现了非受控组件。 这个时候我们更推荐使用非受控组件。...集成具有不受控制组件的 React 和非 React 代码更容易,因为不受控制的组件在 DOM 中维护其事实来源。如果您希望代码数量快速而粗糙,则代码数量也会略有减少。... 不受控制组件的限制 无即时字段验证 无法有条件地禁用提交按钮 无法强制执行输入格式 单个数据没有多个输入 无动态输入 小结 总体而言,非受控组件可以在必要时使用或比受控组件更有效...若要使用非受控制的组件,可以使用 ref 直接访问 DOM 值。对于受控组件,我们将表单数据值存储在 React 组件的状态属性中。

    2.4K20

    antd mobile 作者教你写 React 受控组件和非受控组件

    而如果我们稍微对它做一点调整,把原本的内部状态 value 去掉,放到 props 上去,它就变成了受控组件: 很显然,此时输入框的值是取决于外部传递进来的 props。...如果我们画个图,那可以很清楚的看到受控和非受控的区别: 图中蓝色的方框表示组件,黄色的圆圈表示组件内的状态。 既受控组件又非受控?...尽管在业务项目中,我们写的组件都是明确的受控或者非受控,但对于组件库来说,有非常多的组件需要做到既支持受控模式,又支持非受控模式。...以 antd-mobile 现在的 5.17 版本为例,几乎全部的涉及到输入值、切换、展开收起的组件,都是需要做到既受控又非受控的。...,会发现,为什么还需要判断根据受控和非受控模式来使用不同的值呢?

    2K10

    React--11: refs与事件处理非受控组件和受控组件

    ---- 这是我参与8月更文挑战的第18天,活动详情查看:8月更文挑战 1. 非受控组件 页面所有输入类的DOM,现用现取就是非受控组件。...form 提交触发handleSubmit方法 form中有两个输入项 ,用到回调函数ref ,并添加name属性 handleSubmit方法 阻止页面跳转 ,并弹出提交的用户名和密码 class Login...受控组件 受控组件就是把值都存在了状态当中,当我们使用值时去状态state中取。 首先,受控组件不能使用ref了。那我们想改变值怎么办呢?...给输入框添加onChange事件,只要输入框的值改变就会触发一个函数。...用户名: 这个函数传入的参数就是事件,通过target.value就能获得输入框的值

    54110

    React学习(6)—— 高阶应用:非受控组件

    非受控组件 使用非受控组件 在大部分情况下,推荐使用 受控组件 来实现表单、输入框等状态控制。在受控组件中,表单等数据都有React组件自己处理。...这里将介绍另外一种非受控组件,表单的数据有Dom自己控制。 非受控组件实现的重点是用Refs特性获取真实Dom来代替每次数据变更去更新组件的状态值。...例如下面的代码,在非受控组件中记录被用户输入的名字: class NameForm extends React.Component { constructor(props) { super(...由于在非受控组件中使用Refs特性获取了真实Dom的实例,所以在使用非受控组建时,更容易集成React和非React代码,在某些时候也可以省略一些代码。但是建议除了特殊情况,都使用受控组件。...如果想要深入理解什么情况下使用哪种组件,建议阅读 受控和不受控表单输入 一文。 组件默认值 在React渲染的生命周期,表单中的value属性会被覆盖Dom中的value值。

    64120

    React技巧之表单提交获取input值

    ~ 总览 在React中,通过表单提交获得input的值: 在state变量中存储输入控件的值。...我们使用useState钩子来跟踪输入控件的值。...然而,这并不是必须的,如果你不想设置初始值,你可以省略这个属性。 当使用不受控制的输入控件时,我们使用ref来访问input元素。useRef()钩子可以被传递一个初始值作为参数。...useRef钩子创建了一个普通的JavaScript对象,但在每次渲染时都给你相同的ref对象。换句话说,它几乎是一个带有.current属性的记忆化对象值。...不管你的表单有多少不受控制的输入控件,只要调用reset()方法就可以清除所有的字段。 当表单被提交时,获取输入控件值的另一种方法是,使用name属性访问表单元素。

    1.6K20

    React技巧之设置input值

    ~ 总览 在React中,通过按钮点击设置输入框的值: 声明一个state变量,用于跟踪输入控件的值。...要更新输入控件的状态,只需更新state变量。如果你需要清除输入控件的值,把它设置为空字符串。 或者,你也可以使用不受控制的输入控件。...然而,这并不是必须的,如果你不想设置初始值,你可以省略这个属性。 当使用不受控制的输入控件时,我们使用ref来访问input元素。useRef()钩子可以被传递一个初始值作为参数。...useRef钩子创建了一个普通的JavaScript对象,但在每次渲染时都给你相同的ref对象。换句话说,它几乎是一个带有.current属性的记忆化对象值。...你不应该在一个不受控制的input(一个没有onChange处理函数的输入控件)上设置value属性,因为这将使输入控件不可变,你将无法在其中键入。

    2K10

    美团前端一面必会react面试题4

    state 是多变的、可以修改,每次setState都异步更新的。React中什么是受控组件和非控组件?...(2)非受控组件 如果一个表单组件没有value props(单选和复选按钮对应的是checked props)时,就可以称为非受控组件。在非受控组件中,可以使用一个ref来从DOM获得表单值。...因为非受控组件将真实数据储存在 DOM 节点中,所以在使用非受控组件时,有时候反而更容易同时集成 React 和非 React 代码。...DOM如果是现用现取的称为非受控组件,而通过setState将输入的值维护到了state中,需要时再从state中取出,这里的数据就受到了state的控制,称为受控组件。...可以是带有一个render()方法的类,简单点也可以定义为一个函数。这两种情况下,它都把属性props作为输入,把返回的一棵元素树作为输出。

    3K30

    受控组件和非受控组件

    受控组件和非受控组件 React的受控组件与非受控组件的概念是相对于表单而言的,在React中表单元素通常会持有一下内部的state,因此它的工作方式与其他HTML元素不一样,而获取表单元素内部state...的实现方式的不同,就产生了受控组件和非受控组件。...受控组件 在HTML的表单元素中,它们通常自己维护一套state,并随着用户的输入自己进行UI上的更新,这种行为是不被我们程序所管控的,而如果将React里的state属性和表单元素的值建立依赖关系,再通过...onChange事件与setState()结合更新state属性,就能达到控制用户输入过程中表单发生的操作,React以这种方式控制取值的表单输入元素就叫做受控组件。...非受控组件 如果一个表单组件没有value prop就可以称为非受控组件。 非受控组件是一种反模式,它的值不受组件自身的state或props控制。

    1.6K10

    React报错之react component changing uncontrolled input

    如果message变量的值存储为undefined,我们将空字符串作为备用值进行返回。 useState 另一种解决方案是,在useState钩子中为state变量传递初始值。...一旦用户在input中开始输入,value属性就会被传递到input表单,输入就会从不受控变为受控,这是不被允许的。...你可以使用defaultValue属性来为不受控制的input传递初始值。然而,这一步骤不是必要的,如果你不想设置初始值,你可以省略该属性。...当使用不受控制的input表单时,我们使用ref来访问input元素。每当用户点击例子中的按钮时,不受控制的input 的值都会被记录下来。...你不应该为不受控制的input设置value属性,因为这将使input表单不可变,你将无法在其中输入。

    37520

    年前端react面试打怪升级之路

    参考:前端react面试题详细解答React中什么是受控组件和非控组件?...(2)非受控组件 如果一个表单组件没有value props(单选和复选按钮对应的是checked props)时,就可以称为非受控组件。在非受控组件中,可以使用一个ref来从DOM获得表单值。...因为非受控组件将真实数据储存在 DOM 节点中,所以在使用非受控组件时,有时候反而更容易同时集成 React 和非 React 代码。...如果你不介意代码美观性,并且希望快速编写代码,使用非受控组件往往可以减少你的代码量。否则,你应该使用受控组件。...DOM如果是现用现取的称为非受控组件,而通过setState将输入的值维护到了state中,需要时再从state中取出,这里的数据就受到了state的控制,称为受控组件。

    2.2K10
    领券