react受控组件和非受控组件区别

news/2024/7/15 20:12:05 标签: react.js, 前端, javascript

        React是一种流行的JavaScript库,用于构建用户界面。在React中,组件是构建块,而受控组件和非受控组件是两种不同的组件状态管理方式。本篇博客将深入探讨受控组件和非受控组件的区别,以及它们在React应用中的应用场景。 

什么是受控组件?

在React中,受控组件是由React状态(state)控制的组件。这意味着组件的状态和用户输入是直接关联的。当用户与输入元素(如文本框或复选框)交互时,组件的状态会更新,从而反映用户的输入。

javascript">import React, { useState } from 'react';

const ControlledComponent = () => {
  const [inputValue, setInputValue] = useState('');

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

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

       

在上面的例子中,inputValue的状态受React控制,通过onChange事件更新状态。

什么是非受控组件?

相比之下,非受控组件是由DOM本身控制的组件。React不直接管理这些组件的状态,而是通过对DOM的引用来获取和更新组件的值。

javascript">import React, { useRef } from 'react';

const UncontrolledComponent = () => {
  const inputRef = useRef();

  const handleClick = () => {
    alert(`Input value: ${inputRef.current.value}`);
  };

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

在这个例子中,通过inputRef引用DOM元素,而不是使用React状态来管理输入的值。

区别与应用场景:

  1. 状态管理:

    • 受控组件:通过React状态管理组件的值。
    • 非受控组件:直接通过DOM引用管理组件的值。
  2. 数据流:

    • 受控组件:数据流是双向的,即用户输入会更新React状态,反之亦然。
    • 非受控组件:数据流是单向的,需要通过DOM引用来获取用户输入。
  3. 适用场景:

    • 受控组件:适用于需要对用户输入进行精确控制和处理的场景,例如表单验证。
    • 非受控组件:适用于简单的交互,不需要在React中进行状态管理的场景,例如集成第三方库。

结论

        在React应用中,选择受控组件或非受控组件取决于项目的需求和开发者的偏好。受控组件提供了更精确的控制和更丰富的React生命周期方法,而非受控组件则更接近原始的DOM操作方式,适用于简单的场景。在实际开发中,可以根据具体情况选择合适的组件状态管理方式。


http://www.niftyadmin.cn/n/5259304.html

相关文章

短视频时代,不直播带货怎么获得一手流量?

我是电商珠珠 短视频的出现改变了每个人的娱乐方式&#xff0c;国内的三大巨头&#xff1a;快手、视频号、抖音&#xff0c;这三个的市场定位也有着一定的区别。 快手最早成立于12年11月&#xff0c;面对的用户比较广&#xff0c;整体定位三四线城市&#xff0c;男女均衡。其…

做数据分析为何要学统计学(8)——总体不服从正态分布时使用什么假设检验方法?

大多数情况下&#xff0c;我们都假设样本所在总体服从正态分布&#xff0c;然后使用t检验、方差分析等假设检验方法。但是总体如果不服从正态分布&#xff0c;那么就得使用非参数检验方法&#xff0c;如Mann-Whitney U检验和Wilcoxon秩和检验。其中Mann-Whitney U检验适用于独立…

springboot实战项目之使用AOP技术实现各种角色的鉴权功能

前言 项目开发需求&#xff0c;会员有不同的角色&#xff0c;不同的角色被赋予不同的权限&#xff0c;这就需要对会员的操作进行鉴权处理。 方案 采用aop&#xff0c;可实现满足这种需求&#xff0c;创建匿名类。对外提供接口的时候都会拦截&#xff0c;这种会有弊端&#x…

鸿蒙4.0开发 - DevEco Studio如何使用Previewer窗口预览器报错

DevEco Studio预览器概况在HarmonyOS应用开发过程中&#xff0c;通过使用预览器&#xff0c;可以查看应用的UI效果&#xff0c;方便开发者实时查看应用的运行效果&#xff0c;随时调整代码。 1.正常启动 打开预览器的位置在DevEco Studio编辑界面的右上角部分&#xff0c;竖排…

win10中CMD找不到adb的解决方法

问题描述&#xff1a; 在cmd命令行输入”adb devices” 时就会出现”adb不是内部命令或者外部命令….”&#xff0c;出现这个问题主要是windows系统环境变量没设置好。 配置环境变量 找到本地 adb.exe 程序所在目录&#xff0c;复制当前目录&#xff1b;找到高级系统设置 &g…

C_8练习题答案

一、单项选择题(本大题共20小题,每小题2分,共40分。在每小题给出的四个备选项中,选出一个正确的答案,并将所选项前的字母填写在答题纸的相应位置上。) 编写C语言程序一般需经过的几个步骤依次是(B)。A.编辑、调试、编译、连接 B.编辑、编译、连接、运行 C.编译、调试、编辑、连…

FindMy技术用于手表

手表是一种用于计时和显示时间的仪器&#xff0c;通常由机械、电子或石英等机制驱动。手表可以作为配饰佩戴在手腕上&#xff0c;具有方便携带、时尚美观等特点。手表的种类和款式很多&#xff0c;可以根据不同的需求和场合进行选择。常见的手表类型包括机械表、石英表、电子表…

声明式编程Declarative Programming

接下来要介绍第五种编程范式 -- 声明式编程。分别从它的优缺点、案例分析和适用的编程语言这三个方面来介绍这个歌编程范式。 声明式编程是一种编程范式&#xff0c;其核心思想是通过描述问题的性质和约束&#xff0c;而不是通过描述解决问题的步骤来进行编程。这与命令式编程…