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

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu