React(react18)中组件通信03——简单使用 Context 深层传递参数

React(react18)中组件通信03——简单使用 Context 深层传递参数

  • 1. 前言
    • 1.1 React中组件通信的其他方式
    • 1.2 引出 Context
  • 2. 简单例子
  • 3. 语法说明
    • 3.1 createContext(defaultValue)
    • 3.2 value
    • 3.3 useContext(SomeContext)
  • 4. 总结
    • 4.1 Context
      • 4.1.1 Context 小总结
      • 4.1.2 Context 应用场景
      • 4.1.3 Context-官网
    • 4.2 createContext
    • 4.3 useContext()
  • 5. 附代码

1. 前言

1.1 React中组件通信的其他方式

  • React(react18)中组件通信01——props.
  • React(react18)中组件通信02——消息订阅与发布、取消订阅以及卸载组件时取消订阅.

1.2 引出 Context

  • 需求场景:
    • 我们知道,如果父传子,可以通过props,如果子再传孙,还可以通过props,但是如果家族庞大,组件关系如果一颗大树,一直向下传递,这时候如果还用props,明显就显得有点费劲了。
      • 而且如果这个参数子不要孙要的情况,通过props逐层传递也不是很合理。
      • 再或者,如果这个后代离根太远了,如果还用props逐层传递下去,那么传递 props 会变的十分冗长和不便。
    • 这就需要考虑怎么能跳过中间代还能给后后代传递呢?这就需要接下来要介绍的Context了……
  • 使用 Context 可以深层传递参数,它可以在组件树不需要 props 将数据“直达”到所需的组件中,看官网介绍:
    在这里插入图片描述
    在这里插入图片描述

2. 简单例子

  • 先看实现的效果,如下是:爷爷组件给孙组件传消息:
    在这里插入图片描述
  • 代码设计——目录结构
    在这里插入图片描述
  • 代码设计——代码实现
    • context.js + App.js + index.js
      在这里插入图片描述
    • Parent.jsx + Child.jsx + GrandSon.jsx
      在这里插入图片描述

3. 语法说明

3.1 createContext(defaultValue)

  • 如下:
    在这里插入图片描述

3.2 value

  • value:该值为你想传递给所有处于这个 provider 内读取该 context 的组件,无论它们处于多深的层级。context 的值可以为任何类型。该 provider 内的组件可通过调用 useContext(SomeContext) 来获取它上面最近的 context provider 的 value

3.3 useContext(SomeContext)

  • 在组件的顶层调用 useContext 来读取和订阅 context。
    在这里插入图片描述

4. 总结

4.1 Context

4.1.1 Context 小总结

  • Context 使组件向其下方的整个树提供信息。
  • 传递 Context 的方法:
    • 通过 export const MyContext = createContext(defaultValue) 创建并导出 context。
    • 在无论层级多深的任何子组件中,把 context 传递给 useContext(MyContext) Hook 来读取它。
    • 在父组件中把 children 包在 <MyContext.Provider value={...}> 中来提供 context。
  • Context 会穿过中间的任何组件。
  • Context 可以让你写出 “较为通用” 的组件。
  • 在使用 context 之前,先试试传递 props 或者将 JSX 作为 children 传递。

4.1.2 Context 应用场景

  • 看官网介绍:
    在这里插入图片描述

4.1.3 Context-官网

  • 如下:
    https://zh-hans.react.dev/learn/passing-data-deeply-with-context.

4.2 createContext

  • 上下文使得组件能够无需通过显式传递参数的方式 将信息逐层传递。
  • 任何组件外调用 createContext 来创建一个或多个上下文。
    因为,通常,来自不同文件的组件都会需要读取同一个 context。因此,在一个单独的文件内定义 context 便成了常见做法。你可以使用 export 语句 将其导出,以便其他文件读取使用
  • 参考官网:
    https://zh-hans.react.dev/reference/react/createContext#createcontext.

4.3 useContext()

  • 如果 React 没有在父树中找到该特定 context 的任何 provider,useContext() 返回的 context 值将等于你在 创建 context 时指定的 默认值;
  • 注意,只有在 上层根本没有匹配的 provider 时才使用 createContext(defaultValue)调用的默认值。如果存在 <SomeContext.Provider value={undefined}> 组件在父树的某个位置,调用 useContext(SomeContext) 的组件 将会 接收到 undefined 作为 context 的值。
  • 参考官网:
    https://zh-hans.react.dev/reference/react/useContext.

5. 附代码

  • context.js

    /*** 1. 通常,来自不同文件的组件都会需要读取同一个 context。* 2. 因此,在一个单独的文件内定义 context 便成了常见做法。* 3. 你可以使用 export 语句 将其导出,以便其他文件读取使用*/
    import { createContext } from "react";const MessegeContext = createContext();export default MessegeContext;// import { createContext } from 'react';// export const ThemeContext = createContext('light');
    // export const AuthContext = createContext(null);
    
  • Parent.jsx

    import React from "react";
    import Child from "./Child";
    import './index.css'
    import { useState } from "react";
    import MessegeContext from "./context.js";function Parent() {const [notice, setNotice] = useState('孙子,你真棒!!');return(// <div className="parent">//     我是父组件!//     <div className="child">//         <Child notice={'通知——今天放假!'}/>//     </div>// </div>// 这里的属性,只能用 value<MessegeContext.Provider value={notice}><div className="parent">我是父组件!<div className="child"><Child notice={'通知——今天放假!'}/></div></div></MessegeContext.Provider>)
    }export default Parent;
    
  • Child.jsx

    import React from "react";
    import GrandSon from "./GrandSon";
    import './index.css'function Child(props){return(<div>我是子组件!!!<br /><br />收到来自于父组件的数据:{props.notice}<br /><br /><div className="grandSon"><GrandSon /></div></div>)
    }export default Child;
    
  • GrandSon.jsx

    import { useContext } from "react"
    import MessegeContext from "./context.js";export default function GrandSon(){// 在组件的顶层调用 useContext 来读取和订阅 context。const msgContent = useContext(MessegeContext);console.log(msgContent);return(<div>我是孙组件!!<br />我收到爷爷的信息是:{msgContent}</div>)
    }
    
  • componenet–>index.css

    .parent{background-color: blueviolet;border: 1px solid;height: 900px;width: 600px;text-align: center;
    }.child{background-color: green;height: 300px;margin: 20px;
    }.grandSon{background-color: grey;height: 150px;margin: 20px;
    }
    

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32 Cubemx 通用定时器 General-Purpose Timers同步

文章目录 前言简介cubemx配置 前言 持续学习stm32中… 简介 通用定时器是一个16位的计数器&#xff0c;支持向上up、向下down与中心对称up-down三种模式。可以用于测量信号脉宽&#xff08;输入捕捉&#xff09;&#xff0c;输出一定的波形&#xff08;比较输出与PWM输出&am…

【JAVA】多态的概念与实际利用

个人主页&#xff1a;【&#x1f60a;个人主页】 系列专栏&#xff1a;【❤️初识JAVA】 前言 在面向对象(OOP)的程序设计语言中&#xff0c;多态与封装、继承合称为OOP的三大特性。在今天&#xff0c;我们就来学习一下JAVA中的多态是什么样子的。、 多态 指一个对象在不同…

【LeetCode每日一题】——面试题10.11.峰与谷

文章目录 一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【题目提示】七【解题思路】八【时间频度】九【代码实现】十【提交结果】 一【题目类别】 排序 二【题目难度】 中等 三【题目编号】 面试题10.11.峰与谷 四【题目描述】 在一个整数…

Java21 LTS版本

一、前言 除了众所周知的 JEP 之外&#xff0c;Java 21 还有更多内容。首先请确认 java 版本&#xff1a; $ java -version openjdk version "21" 2023-09-19 OpenJDK Runtime Environment (build 2135-2513) OpenJDK 64-Bit Server VM (build 2135-2513, mixed mo…

Visual Studio将C#项目编译成EXE可执行程序

经常看文章时会收获不少实用工具&#xff0c;有的在github上是编译好的&#xff0c;有的则是未编译的项目文件。所以经常会使用Visual Studio编译项目文件成exe可执行程序&#xff0c;以下为编译的流程。 第一步&#xff0c;从github上下载项目文件&#xff0c;举个例子&#…

减速带数据集950张

减速带是安装在公路上使经过的车辆减速的交通设施&#xff0c;形状一般为条状&#xff0c;也有点状的&#xff0c;材质主要是橡胶&#xff0c;也有的是金属的&#xff0c;一般以黄色黑色相间以引起视觉注意&#xff0c;使路面稍微拱起以达到车辆减速目的。 今天要介绍的数据集…

【云原生】k8s-----集群调度

目录 1.k8s的list-watch机制 1.1 list-watc机制简介 1.2 根据list-watch机制&#xff0c;pod的创建流程 2.scheduler的调度策略 2.1 scheduler的调度策略简介 2.2 Scheduler预选策略的算法 2.3 Scheduler优选策略的算法 3. k8s中的标签管理及nodeSelector和nodeName的 调…

无人机航测没信号?北斗卫星来解决

无人机航测是利用无人机进行地理信息的采集和处理的航测方式。相比传统的航测手段&#xff0c;无人机航测具备更高的灵活性、更低的成本和更广阔的适应性。无人机航测可以应用于土地测绘、农业植保、城市规划、自然资源调查等多个领域&#xff0c;极大地提高了测绘的效率和准确…

服务器搭建(TCP套接字)-epoll版(服务端)

epoll 是一种在 Linux 系统上用于高效事件驱动编程的 I/O 多路复用机制。它相比于传统的 select 和 poll 函数具有更好的性能和扩展性。 epoll 的主要特点和原理&#xff1a; 1、事件驱动&#xff1a;epoll 是基于事件驱动的模型&#xff0c;它通过监听事件来触发相应的回调函…

DM/达梦数据库查询或更新某一列中多个字典码对应内容

准备工作&#xff08;建表、插入数据&#xff09; 1、建立表格&#xff1a;学生-学习科目表student_study 注意&#xff1a;科目kemu列内容是字典码&#xff0c;需要更换成对应内容。 CREATE TABLE "TEST"."STUDENT_STUDY" ( "NAME" VARCHAR(2…

【C语言】进阶——指针

目录 ①(●◡●)前言 1.字符指针 ✌字符指针和数组笔试题 2.指针数组 和数组指针 &#x1f44a;指针数组 &#x1f44a;数组指针 &#x1f44a;&数组名和数组名 3.数组传参和指针传参 &#x1f44a;一维数组传参 &#x1f44a;二维数组传参 &#x1f44a;一级…

Linux内核源码分析 (B.7)深入理解 slab cache 内存分配全链路实现

Linux内核源码分析 (B.7)深入理解 slab cache 内存分配全链路实现 文章目录 Linux内核源码分析 (B.7)深入理解 slab cache 内存分配全链路实现1\. slab cache 如何分配内存2\. slab cache 的快速分配路径3\. slab cache 的慢速分配路径3.1 从本地 cpu 缓存 partial 列表中分配3…