React状态与引用(Refs)- 差异和使用场景

2024-04-14 05:04

本文主要是介绍React状态与引用(Refs)- 差异和使用场景,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在本文中,我们将深入比较React的staterefs,探讨它们在特定场景下的适用性。

当需要在React应用程序中存储数据时,首先要考虑的问题是:“数据是否在组件的生命周期内的某个时刻发生变化?” 如果不会,那么普通的const变量非常适合。

然而,如果数据会发生变化,那么就需要使用useStateuseRef钩子。

(本文视频讲解:java567.com)

理解useState和useRef钩子

useState钩子

useState钩子旨在管理组件的状态,表示随时间变化的数据,并且对于组件渲染非常重要。您可以通过从React导入useState钩子来向组件添加状态。

import { useState } from 'react';

useState钩子通常使用初始值进行初始化,并返回一个声明的状态变量及其关联的设置器函数的数组。它的用法如下:

import { useState } from "react";function App() {const [count, setCount] = useState(0); //声明useState钩子return (<><h1>状态示例</h1><div><button onClick={() => setCount((count) => count + 1)}>数量为 {count}</button></div></>);
}
export default App;

在上面的代码中,

  1. useState用零值初始化,并返回一个count变量和一个setCount设置器函数。
  2. count变量由setCount设置器函数动态设置,该函数将count增加1。
  3. 对于每次按钮点击,都会重新渲染App组件,并在按钮文本中显示更新后的值。

了解React状态是很重要的,因为它是最常用的概念之一。

useRef钩子

useRef钩子用于在React组件中创建引用。引用是一个具有current属性的对象,该属性保存一个值。它基本上引用了一个DOM元素或组件的实例。我们可以通过访问current属性来读取和更新值。

const ref = useRef(initialValue)ref.current = initialValue

下面是引用在实际中的完整代码片段:

import { useRef } from "react";function App() {let ref = useRef(0); function handleIncrease() {ref.current++;alert(`您已点击了${ref.current}次`);}return (<><h1>引用示例</h1><div><button onClick={handleIncrease}>点击我</button></div></>);
}export default App;

让我们来分解一下:

  1. 我们从React中导入了useRef
  2. 在我们的App组件中,我们声明了一个ref对象,初始值设置为零。
  3. handleIncrease是我们的处理函数,它将ref.current的值增加1,然后警告用户当前值。
  4. 在我们的App组件的JSX中,我们有一个带有onClick属性和传递给它的handleIncrease处理函数的按钮。

了解了这两个钩子的工作原理后,我们将继续比较和探讨它们何时适合使用。

React状态与引用(Ref)

渲染触发

在React中,状态总是触发重新渲染,这是由一种称为“协调(reconciliation)”的机制所致——根据对状态或props所做的更改来更新用户界面。

在幕后,React将新状态与先前状态进行比较,并计算出更新用户界面所需的最小更改。这个过程确保了与更改后的状态或props的一致性。

另一方面,当对引用进行更改时,引用不会触发重新渲染。引用并不直接与组件的渲染周期相关联。

因此,如果您希望拥有对数据更改做出反应的一致性用户界面,则建议使用状态。引用更适合用于管理可变值,而不影响用户界面。

可变性

React状态一旦设置就无法直接更改,因为状态变量的设置器函数会更新。通过使用这种方法,React保持了数据流的可预测性和稳定性。这也有助于使调试更加容易。

相反,引用是可变的,因为您可以在渲染过程之外修改ref current值。与状态不同,可以在任何时候更改值——引用没有更新函数。

读/写操作

useState钩子的设置器函数允许您更新状态值。例如:

const [state, setState] = useState(false)
function handleOpposite(){setState(!state)}

在这段代码中,我们可以看到:

  1. 初始值设置为布尔值false
  2. handleOpposite函数对state的布尔值进行了否定,而setState存储了更新后的true值。

在这个简单的操作中,

  1. 隐式的操作是必要的,因为在否定之前必须访问初始值。
  2. 当对初始值使用否定(!)时,发生了操作,这将值更改为相反值。

状态的显式操作发生在您在组件的JSX中直接访问状态变量时。例如:

<button onClick={() => setCount((count) => count + 1)}>数量为 {count}</button>

{count}是当前访问的状态值,并将相应地显示在UI上。

另一方面,在渲染过程中访问或修改ref的当前值可能会干扰React的协调过程,可能导致虚拟DOM和实际DOM之间的不一致。

为了确保组件行为的可预测性和性能的最佳表现,最好遵守React的指导方针,并在渲染过程中避免访问或修改引用。

跨渲染保持不变

在React中跨渲染保持数据不变意味着数据在组件的不同渲染周期之间保持一致和可用。当数据持久化时,它在重新渲染后保持不变且可访问。状态和引用都可以在渲染过程中保持数据不变。

持久性对于维护应用程序状态的完整性至关重要,并确保组件的操作符合预期。

异步更新

在React中,状态的更新是异步的,这意味着当有更新请求时,更新可能不会立即执行。React可能会将某些状态更改留到以后再更新,同时一次性更新其他组件!

引用更新是同步进行的,其中任务按顺序进行。每个任务在前一个任务完成后开始,确保它们以可预测和确定的方式执行。

结论

在本文中,我们广泛地介绍了处理React应用程序中动态数据(即将更改的数据)的钩子——useStateuseRef

我们比较了这两个钩子,现在您应该了解它们的相似之处、差异之处以及它们最适合使用的场景和时机。

(本文视频讲解:java567.com)

这篇关于React状态与引用(Refs)- 差异和使用场景的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/902125

相关文章

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,