react 中 useContext Hook 作用

`useContext`是一个用于在组件之间共享数据的重要钩子函数

一、跨组件数据共享

1. 简化多层级组件数据传递

例如:在一个具有多层级菜单结构的应用中,如果要将用户权限数据从根组件传递到最深层的菜单项组件,可能需要经过多个中间组件的 props 传递,使得代码变得复杂且难以维护。而`useContext`提供了一种解决方案,通过创建和使用上下文,可以直接在需要数据的组件中获取,无需经过中间组件的层层传递。

2. 代码示例

// 创建一个上下文

const UserContext = React.createContext();



// 在顶层组件中提供数据

const App = () => {

  const userData = { name: "John", role: "admin" };

  return (

    <UserContext.Provider value={userData}>

      <ComponentA />

    </UserContext.Provider>

  );

};



// 深层嵌套的组件可以直接获取数据

const ComponentC = () => {

  const userData = React.useContext(UserContext);

  return (

    <div>

      {userData.name} - {userData.role}

    </div>

  );

};



const ComponentB = () => {

  return <ComponentC />;

};



const ComponentA = () => {

  return <ComponentB />;

};

二、实现全局数据共享

1. 应用场景

例如:在一个多语言应用中,语言环境数据可以通过上下文在整个应用的各个组件中共享。当语言环境发生改变时,所有使用该语言环境数据的组件都可以方便地做出响应。

2. 代码示例

// 创建语言环境上下文

const LanguageContext = React.createContext();



// 在顶层组件中设置语言环境

const App = () => {

  const language = "en";

  return (

    <LanguageContext.Provider value={language}>

      <Header />

      <MainContent />

      <Footer />

    </LanguageContext.Provider>

  );

};



// 不同的组件可以获取语言环境数据

const Header = () => {

  const language = React.useContext(LanguageContext);

  // 根据语言环境渲染不同的标题

  return language === "en" ? <h1>English Title</h1> : <h1>中文标题</h1>;

};



const MainContent = () => {

  const language = React.useContext(LanguageContext);

  // 根据语言环境显示不同的内容

  return language === "en" ? <p>English Content</p> : <p>中文内容</p>;

};



const Footer = () => {

  const language = React.useContext(LanguageContext);

  // 根据语言环境显示不同的版权信息

  return language === "en" ? (

    <p>Copyright in English</p>

  ) : (

    <p>版权信息(中文)</p>

  );

};

三、组件状态的统一管理

1. 共享状态的更新与同步

例如:在一个主题切换的应用中,如果通过上下文共享了主题颜色状态,当用户切换主题颜色时,改变上下文的主题颜色值,所有使用该主题颜色的组件都会根据新的值重新渲染。

2. 代码示例

// 创建主题颜色上下文

const ThemeContext = React.createContext();



// 主题切换组件

const ThemeToggle = () => {

  const [theme, setTheme] = React.useState("light");

  const toggleTheme = () => {

    setTheme(theme === "light" ? "dark" : "light");

  };

  return (

    <ThemeContext.Provider value={theme}>

      <button onClick={toggleTheme}>Toggle Theme</button>

      <ComponentUsingTheme />

    </ThemeContext.Provider>

  );

};



// 使用主题颜色的组件

const ComponentUsingTheme = () => {

  const theme = React.useContext(ThemeContext);

  const backgroundColor = theme === "light" ? "white" : "black";

  const color = theme === "light" ? "black" : "white";

  return (

    <div style={{ backgroundColor, color }}>

      This component uses the {theme} theme.

    </div>

  );

};

四、与其他状态管理方法的结合

1. 与 Redux 或 useReducer 的协同作用

例如:在使用`useReducer`管理复杂状态的同时,可以通过`useContext`将状态和更新状态的`dispatch`函数在组件之间共享。这样,既可以利用`useReducer`的可预测状态更新逻辑,又可以通过`useContext`方便地在多个组件中使用和更新状态。

2. 代码示例

// 创建一个上下文来传递状态和dispatch函数

const StateContext = React.createContext();



// 定义reducer和初始状态

const reducer = (state, action) => {

  switch (action.type) {

    case "INCREMENT":

      return { count: state.count + 1 };

    case "DECREMENT":

      return { count: state.count - 1 };

    default:

      return state;

  }

};



const initialState = { count: 0 };



// 在顶层组件中使用useReducer并通过上下文共享

const App = () => {

  const [state, dispatch] = React.useReducer(reducer, initialState);

  return (

    <StateContext.Provider value={{ state, dispatch }}>

      <Counter />

    </StateContext.Provider>

  );

};



// 组件可以通过useContext获取状态和dispatch函数

const Counter = () => {

  const { state, dispatch } = React.useContext(StateContext);

  return (

    <div>

      <p>Count: {state.count}</p>

      <button onClick={() => dispatch({ type: "INCREMENT" })}>Increment</button>

      <button onClick={() => dispatch({ type: "DECREMENT" })}>Decrement</button>

    </div>

  );

};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/915449.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

丹摩征文活动 | 丹摩智算平台:服务器虚拟化的璀璨明珠与实战秘籍

丹摩DAMODEL&#xff5c;让AI开发更简单&#xff01;算力租赁上丹摩&#xff01; 目录 一、引言 二、丹摩智算平台概述 &#xff08;一&#xff09;平台架构 &#xff08;二&#xff09;平台特点 三、服务器虚拟化基础 &#xff08;一&#xff09;虚拟化的概念 &#xf…

蓝牙5.0模块助力闹钟升级,开启智能生活第一步

随着智能家居产业的快速发展&#xff0c;智能闹钟作为其中一个重要的品类&#xff0c;逐渐从单一的时间提醒功能演变为集音频播放、语音交互、智能控制等多种功能于一体的智能设备。而在这些功能的实现中&#xff0c;蓝牙音频模组扮演着核心角色。 1、蓝牙音频模组的功能概述 …

POI word转pdf乱码问题处理

1.使用poi 转换word文档成pdf 导入依赖 <dependency><groupId>com.aspose</groupId><artifactId>words</artifactId><version>16.8.0</version></dependency>2.代码实现: SneakyThrowspublic void wordToPdf(String docPath,…

有趣的Midjourney作品赏析(附提示词)

中文提示词&#xff1a;国风少年 C4D软件,高分辨率,超细节,超现实主义, 英文提示词&#xff1a;National Style Youth Cinema4D,high resolution,hyper detailed,surrealism, --niji 6 --ar 1:1 中文提示词&#xff1a;粘土模型&#xff0c;男性穿着中世纪欧洲蓝色盔甲&#x…

猫头虎分享: 小米大模型升级第二代MiLM2:从一代到二代,能力飞跃提升

小米大模型升级第二代MiLM2&#xff1a;从一代到二代&#xff0c;能力飞跃提升 大家好&#xff0c;我是猫头虎&#xff0c;今天给大家带来一篇关于小米大模型MiLM2的深度解读。作为技术圈的重磅消息&#xff0c;小米的第二代大模型&#xff08;MiLM2&#xff09;在多项领域实现…

解决Anaconda出现CondaHTTPError: HTTP 000 CONNECTION FAILED for url

解决Anaconda出现CondaHTTPError: HTTP 000 CONNECTION FAILED for url 第一类情况 在anaconda创建新环境时&#xff0c;使用如下代码 conda create -n charts python3.7 错误原因&#xff1a; 默认镜像源访问速度过慢&#xff0c;会导致超时从而导致更新和下载失败。 解决方…

【机器学习】机器学习中用到的高等数学知识-2.概率论与统计 (Probability and Statistics)

概率分布&#xff1a;理解数据的分布特征&#xff08;如正态分布、伯努利分布、均匀分布等&#xff09;。期望和方差&#xff1a;描述随机变量的中心位置和离散程度。贝叶斯定理&#xff1a;用于推断和分类中的后验概率计算。假设检验&#xff1a;评估模型的性能和数据显著性。…

ESLint 使用教程(四):ESLint 有哪些执行时机?

前言 ESLint 作为一个静态代码分析工具&#xff0c;可以帮助我们发现和修复代码中的问题&#xff0c;保持代码风格的一致性。然而&#xff0c;ESLint的最佳实践不仅仅在于了解其功能&#xff0c;更在于掌握其执行时机。本文将详细介绍ESLint在不同开发阶段的执行时机&#xff…

【设计模式系列】享元模式(十五)

目录 一、什么是享元模式 二、享元模式的角色 三、享元模式的典型应用场景 四、享元模式在ThreadPoolExecutor中的应用 1. 享元对象&#xff08;Flyweight&#xff09;- 工作线程&#xff08;Worker&#xff09; 2. 享元工厂&#xff08;Flyweight Factory&#xff09;- …

#渗透测试#SRC漏洞挖掘#云技术基础02之容器与云

免责声明 本教程仅为合法的教学目的而准备&#xff0c;严禁用于任何形式的违法犯罪活动及其他商业行为&#xff0c;在使用本教程前&#xff0c;您应确保该行为符合当地的法律法规&#xff0c;继续阅读即表示您需自行承担所有操作的后果&#xff0c;如有异议&#xff0c;请立即停…

【Linux系统编程】第四十六弹---线程同步与生产消费模型深度解析

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】 目录 1、Linux线程同步 1.1、同步概念与竞态条件 1.2、条件变量 1.2.1、认识条件变量接口 1.2.2、举例子认识条件变量 1.2.3、…

力扣(LeetCode)283. 移动零(Java)

White graces&#xff1a;个人主页 &#x1f649;专栏推荐:Java入门知识&#x1f649; &#x1f439;今日诗词:雾失楼台&#xff0c;月迷津渡&#x1f439; ⛳️点赞 ☀️收藏⭐️关注&#x1f4ac;卑微小博主&#x1f64f; ⛳️点赞 ☀️收藏⭐️关注&#x1f4ac;卑微小博主…

如何在单片机引脚有限时拓展更多引脚

假设单片机有3个GPIO口可以使用&#xff0c;但是我现在要控制多余3个口的功能怎么办&#xff1f; 这个时候可以用到74LS138&#xff08;3 线&#xff0d;8线译码器&#xff09;&#xff1a; 这个时候我使用三位二进制位可以表示2^3 8个引脚的内容 这种方法经常用于选择数码屏…

go debug日记:protoc -I . helloworld.proto --go_out=plugins=grpc:.错误debug

使用protoc生成go的文件出现bug 运行命令 protoc -I . helloworld.proto --go_outpluginsgrpc:.如图所示 即&#xff0c;没有指定生成的go文件位置&#xff0c;需要在文件中添加 option go_package"path;name";其中 path 表示生成的go文件的存放地址&#xff0c;…

cesium渲染3DTiles模型和glb模型

cesium渲染3DTiles模型和glb模型 相关网站&#xff1a; 1.快速入门&#xff1a;https://cesium.com/learn/cesiumjs-learn/cesiumjs-quickstart/ 2.webpack配置&#xff1a;https://github.com/CesiumGS/cesium-webpack-example#cesium-webpack-example 3.说明文档&#xff…

灰狼优化算法

一、简介 1.1 灰狼优化算法-Grey Wolf Optimizer 通过模拟灰狼群体捕食行为&#xff0c;基于狼群群体协 作的机制来达到优化的目的。&#xff27;&#xff37;&#xff2f;算法具有结构简单、需 要调节的参数少、容易实现等特点&#xff0c;其中存在能够自适应调整 的收敛因子…

新日撸java三百行` 新手小白java学习记录 `Day1

新日撸java三百行新手小白java学习记录 Day1 模拟多线程回调机制 文章目录 新日撸java三百行 新手小白java学习记录 前言一 、模拟异步机制提出问题解决方案 前言 古人称长江为江&#xff0c;黄河为河。长江水清&#xff0c;黄河水浊&#xff0c;长江在流&#xff0c;黄河也在…

【Unity Bug 随记】unity version control 报 xx is not in a workspace.

可能原因是更改了仓库或者项目名称。 解决办法就是重置Unity Version Control&#xff0c;去Hub disconnect 然后重新connect cloud和UVC UVC可能连不上&#xff0c;直接进入项目就行&#xff0c;打开版本管理标签会让你重新连工作区&#xff0c;选择你的仓库和工作区 然后In…

Go语言入门教案

文章目录 一、教学目标二、教学重难点&#xff08;一&#xff09;重点&#xff08;二&#xff09;难点 三、教学方法四、教学过程&#xff08;一&#xff09;Go语言简介&#xff08;二&#xff09;环境搭建1. 下载和安装Go语言开发环境2. 配置Go语言环境变量3. 命令行查看Go语言…