”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何在 React 中使用上下文

如何在 React 中使用上下文

发布于2024-11-03
浏览:962

How to use Context in React

欢迎回来,朋友们!


今天我们将回顾名为 useContext 的 React Hook 的基础知识。 useContext 是一个强大的工具,它比 useState 更进一步,创建了一个类似全局的 State,可以将信息传递给子组件和孙组件,而无需直接传递 props。

但我有点超前了。
如果你不熟悉 useState,请先跳过去阅读我之前的文章,然后再回来准备大吃一惊!


如何使用‘useState’:https://dev.to/deborah/how-to-use-state-in-react-2pah

现在您已经了解了“useState”,让我们深入了解“useContext”!

什么是 useContext?:

useContext 非常适合需要放置在全局范围内的数据(例如使某人在整个应用程序中保持登录的用户名),但它并不是最终的快捷方式将 props 传递给子组件。
然而,useContext 允许我们在不直接传递 props 的情况下传递数据,因此当我们遇到需要由多个子组件访问或在整个应用程序中可用的数据时,useContext 非常有用。

为了让 useContext 启动并运行,我们需要执行两个步骤:首先,我们需要创建一个上下文对象('createContext'),然后我们需要使用钩子 'useContext' 通过提供者访问该值。

为了让您更好地了解 useContext 的含义以及如何使用它,以下示例已进行了简化,但您应该注意 createContext 通常在其自己的单独文件中声明。然而,我将“Parent.js”比作典型的“App.js”文件(组件层次结构顶部的组件)。 Parent.js 是我定义所有状态变量、更新这些状态变量的函数,并使用 useEffect 获取数据库的地方。我选择在顶级组件中声明 createContext,而不是创建自己的文件,以简化此说明,以便您可以更好地理解 Context 的核心概念。

话虽如此,让我们从头开始:createContext!

1.我们需要做的第一件事是声明并导出一个名为“Context”的变量,稍后我们将在子组件中使用该变量[我们现在正在创建一个变量,以便使我们的代码更简单,因此我们可以将稍后访问其中的值(数据)]:

export Context = React.createContext();

‘Context’是通过调用‘createContext’创建的上下文对象。上下文对象包含一个名为 Provider 的组件,我们现在可以调用该组件,然后传递我们想要保留在“全局”级别的变量和函数。

2. 使用“Context”变量,现在让我们跳到 return 语句中的 JSX。在这里,我们将调用“Context”并将其包装在开始标签(尖括号)中,并像这样调用 Provider:


return(
    
        // Other JSX & the child components we want to hand Context to.

    
);

为了完成‘Context.Provider’,我们还需要给‘Provider’提供一个值。这是我们将传递一个带有所有变量和函数的对象的地方,我们将在子组件中使用“Context”调用这些变量和函数:

return(
    
        // Other JSX & the child components we want to hand Context to.

    
);

非常重要的是要注意,我们需要将所有将使用变量和函数的子组件放在标签之间。例如:

return(
    
);

请注意,我们不需要将任何 props 直接传递给子组件(就像我们使用“useState”一样),只要我们将 props 放在“value”中即可。

现在我们已经使用了 createContext 并将所有全局项传递给“Context.Provider”,我们准备好继续讨论子组件并了解如何使用“Context”。

3. 让我们看看一个子组件,它(为了本示例)位于文件“Child.js”中。正如编码的生活一样:如果你想使用某些东西,你需要导入它。让我们继续从“Parent.js”中声明它的位置获取“Context”,以便我们可以在这个子组件(“Child.js”)中使用它:

import Context from ‘./Parent.js’;

4. 现在我们可以访问子组件中的“Context”,现在需要将“useContext”导入到文件中,以便我们可以将“Context”传递给它(稍后将详细介绍):

import React, { useContext } from ‘react’;
import Context from ‘./Parent.js’;

5. 太棒了!现在让我们使用“useContext”。首先我们需要声明一个变量来使用“useContext”。我们将在组件内部以与声明 useState 类似的方式执行此操作:

import React, { useContext } from ‘react’;
import Context from ‘./Parent.js’;

function Child(){
    const { example, setExample } = useContext(Context)

    // The rest of our code

在此代码中,我们使用大括号 {} 来表示解构赋值。这是一种奇特的说法,我们可以调用存储在 Context 中的多个变量和函数。我们还将“Context”传递给“useContext”,以便我们可以访问 Context.Provider 中定义的值(我们在“Parent.js”中声明)。



6. 不管你信不信,你已经准备好了!您现在可以在代码中使用上下文值,就像通常使用 State 一样。例如:

const expId = example.id;

或者

setExample(newExample);

让我们回顾一下:

恭喜!您现在拥有开始使用 createContext 和 useContext 的所有工具。您了解 useContext 允许您创建某种“全局状态”,可以将变量和函数传递给组件,而无需直接通过子组件传递 props。

我们还深入研究了在应用程序中获取上下文所需的六个步骤。您现在已准备好开始使用 createContext 和 useContext 进行编码,但如果您需要快速入门指南,请看这里:

在父组件中,使用“createContext”声明并导出一个名为“Context”的变量:

export const Context = React.createContext();

在父组件的 JSX 中,将所有需要访问上下文的子组件包装在 Context.Proivder 中,并在对象内传递任何变量/函数:


   //Child components

在您的子组件中,导入“useContext”:

import React, { useContext } from ‘react’;

还从父组件导入“Context”:

import Context from “./Parent.js’;

然后使用 useContext 并将其传递给您的“Context”变量:

const { example, handleExample } = useContext(Context);

最后,使用您现在可以访问的上下文(在上面的示例中,这将是“example”和“handleExample”),但是您需要在子组件中使用。

干得好!下次再见,祝您编码愉快!

最后一点,如果您想深入研究这个主题,这里是我在学习 useContext 和撰写此博客时也引用的官方文档资源:

官方文档:
https://react.dev/reference/react/createContext

Legacy官方文档,对于理解useContext还是有一定帮助的:https://legacy.reactjs.org/docs/context.html

版本声明 本文转载于:https://dev.to/deborah/how-to-use-context-in-react-3aa9?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何将单个输入字段设置为分区输入?
    如何将单个输入字段设置为分区输入?
    将输入字段设置为分区输入有多种方法可用于创建一系列分区输入字段。一种方法利用“字母间距”来分隔单个输入字段内的字符。此外,“background-image”和“border-bottom”样式可以进一步增强多个输入字段的错觉。CSS Snippet以下 CSS 代码演示了如何创建所需的效果:#pa...
    编程 发布于2024-11-05
  • 用 Go 构建一个简单的负载均衡器
    用 Go 构建一个简单的负载均衡器
    负载均衡器在现代软件开发中至关重要。如果您曾经想知道如何在多个服务器之间分配请求,或者为什么某些网站即使在流量大的情况下也感觉更快,答案通常在于高效的负载平衡。 在这篇文章中,我们将使用 Go 中的循环算法构建一个简单的应用程序负载均衡器。这篇文章的目的是逐步了解负载均衡器的工作原理。 ...
    编程 发布于2024-11-05
  • 如何以超链接方式打开本地目录?
    如何以超链接方式打开本地目录?
    通过超链接导航本地目录尝试在链接交互时启动本地目录视图时,您可能会遇到限制。然而,有一个解决方案可以解决这个问题,并且可以在各种浏览器之间无缝工作。实现方法因为从 HTML 页面直接打开路径或启动浏览器是由于安全原因受到限制,更可行的方法是提供可下载的链接(.URL 或 .LNK)。推荐路径:.UR...
    编程 发布于2024-11-05
  • 为什么 Makefile 会抛出 Go 命令的权限被拒绝错误?
    为什么 Makefile 会抛出 Go 命令的权限被拒绝错误?
    运行 Go 时 Makefile 中出现权限被拒绝错误通过 Makefile 运行 Go 命令时可能会遇到“权限被拒绝”错误,即使你可以直接执行它们。这种差异是由于 GNU make 中的问题引起的。原因:当您的 PATH 上有一个目录包含名为“go.gnu”的子目录时,就会出现此错误。 ”例如,如...
    编程 发布于2024-11-05
  • parseInt 函数中 Radix 参数的意义是什么?
    parseInt 函数中 Radix 参数的意义是什么?
    parseInt 函数中 Radix 的作用parseInt 函数将字符串转换为整数。然而,它并不总是采用以 10 为基数的数字系统。要指定所需的基数,请使用基数参数。理解基数基数是指单个数字表示的值的数量。例如,十六进制的基数为 16,八进制的基数为 8,二进制的基数为 2。为什么使用基数?需要当...
    编程 发布于2024-11-05
  • 在空数据集上使用 MySQL 的 SUM 函数时如何返回“0”而不是 NULL?
    在空数据集上使用 MySQL 的 SUM 函数时如何返回“0”而不是 NULL?
    当不存在任何值时如何从 MySQL 的 SUM 函数中检索“0”MySQL 中的 SUM 函数提供了一种方便的方法来聚合数值价值观。但是,当查询期间没有找到匹配的行时,SUM 函数通常返回 NULL 值。对于某些用例,可能更需要返回“0”而不是 NULL。利用 COALESCE 解决问题此问题的解决...
    编程 发布于2024-11-05
  • 如何使用 JavaScript 将链接保留在同一选项卡中?
    如何使用 JavaScript 将链接保留在同一选项卡中?
    在同一选项卡和窗口中导航链接您可能会遇到想要在同一窗口和选项卡中打开链接的情况作为当前页面。但是,使用 window.open 函数通常会导致在新选项卡中打开链接。为了解决这个问题,您可以使用 name 属性,如下所示:window.open("https://www.youraddres...
    编程 发布于2024-11-05
  • 如何解决Python中的循环依赖?
    如何解决Python中的循环依赖?
    Python 中的循环依赖使用 Python 模块时遇到循环依赖可能是一个令人沮丧的问题。在这个特定场景中,我们有两个文件,node.py 和 path.py,分别包含 Node 和 Path 类。最初,path.py 使用 from node.py import * 导入 node.py。但是,在...
    编程 发布于2024-11-05
  • MariaDB 与 MySQL:开发人员需要了解什么
    MariaDB 与 MySQL:开发人员需要了解什么
    MariaDB 和 MySQL 是著名的开源 RDBMS,但尽管它们有着共同的历史,但它们在功能和性能方面却有所不同。本文快速强调了主要差异,帮助开发人员决定哪个数据库最适合他们的需求。 差异和示例 存储引擎,MariaDB 对 Aria 和 MyRocks 等引擎的扩展支持提供了比...
    编程 发布于2024-11-05
  • 为什么我的 Goroutine 递增变量会产生意外的结果?
    为什么我的 Goroutine 递增变量会产生意外的结果?
    这是编译器优化的结果吗?在此代码片段中,启动了一个 goroutine 并重复递增变量 i:package main import "time" func main() { i := 1 go func() { for { ...
    编程 发布于2024-11-05
  • 利用 AI 快速学习 Node.js - 第 4 天
    利用 AI 快速学习 Node.js - 第 4 天
    今天,借助ChatGPT继续学习Node.js,重点是异步编程。这是 Node.js 中最重要的概念之一,我很高兴能够开始掌握它。 理论 在 Node.js 中,异步编程因其非阻塞、事件驱动的架构而至关重要。这意味着文件读取、数据库查询或网络请求等操作在等待结果时不会阻塞其他代码的执行。 我们探索了...
    编程 发布于2024-11-05
  • Java 可以定义带有嵌入引号的字符串而不转义吗?
    Java 可以定义带有嵌入引号的字符串而不转义吗?
    揭开 Java 使用嵌入式引号定义字符串的替代方法在 Java 中处理字符串时,您常常会在文字中遇到大量引号,导致繁琐的转义和可读性挑战。虽然其他语言提供了处理这种情况的语法,但 Java 缺乏类似的选项。问题: Java 是否提供了另一种方法来定义带有嵌入引号的字符串而不诉诸转义?答案: 虽然 J...
    编程 发布于2024-11-05
  • 耐用的 Python:构建防弹的长期运行工作流程,变得简单
    耐用的 Python:构建防弹的长期运行工作流程,变得简单
    在现代软件开发中,创建强大的工作流程来连接来自各种服务的 API 并处理同步和异步事件是一个常见的挑战。传统方法涉及使用队列、微服务和状态管理系统的组合来构建可扩展的应用程序。虽然有效,但这种架构带来了巨大的开销:设置和维护消息队列等基础设施、运行服务器或 lambda 函数、管理数据库中的状态以及...
    编程 发布于2024-11-05
  • 使用 Node.js 构建实时仪表板
    使用 Node.js 构建实时仪表板
    介绍 在当今快节奏的商业世界中,组织访问实时数据以做出明智的决策至关重要。这就是使用 Node.js 构建实时仪表板发挥作用的地方。 Node.js 是一种流行的、轻量级的、高效的 JavaScript 运行时环境,近年来获得了极大的普及。在本文中,我们将讨论专门使用 Node.j...
    编程 发布于2024-11-05
  • 以下是一些适合您的文章的基于问题的标题,重点关注问题和解决方案:

* 如何跨子域共享localStorage数据?
* 想要在您之间共享本地存储数据
    以下是一些适合您的文章的基于问题的标题,重点关注问题和解决方案: * 如何跨子域共享localStorage数据? * 想要在您之间共享本地存储数据
    如何跨子域共享 localStorage许多网站使用 localStorage 而不是 cookie 来存储数据,因为它提供了更好的性能和安全性。然而,localStorage 在处理子域时可能会带来挑战,因为每个子域都有自己单独的 localStorage 对象。当用户同时使用主域(例如 site...
    编程 发布于2024-11-05

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3