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

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.