React hooks之useContext《类比Vue的Provide》(三)

news2024/11/30 10:28:29

系列文章目录

提示:我又来更新啦!!!这次又把之前useEffect的补充了一次!!!!


文章目录

  • 系列文章目录
  • 前言
    • 1.Vue中的Provide和useContext(相同点)
    • 2..Vue中的Provide和useContext(不同点)
  • 一、useContext的用法(贼简单,自己看官网还容易看不懂)
    • 第一步:创建传值的组件结构(爷爷,父亲,孩子组件)
      • 1.说明如下:
      • 2.结构如下图:
    • 第二步:创建Context(一定要导出)
      • 代码如下
    • 第三步:书写传值姿势
    • 第四步:导入useContext(一定是函数组件)
      • child组件代码如下
      • 说明如下图
    • 第五步:查看传值结果
    • 默认Text按钮
    • 修改成Primary类型按钮
  • 二、如何修改context的值(相当于是多传了一个修改函数)
    • 1.修改索引(代码如下)
    • 2.在child中添加一行代码,调用传下去的函数(一定要传修改的参数!)
  • 总结:⚠️重点注意(我踩的坑)
    • 问题一:为什么第一次渲染的时候不是link类型,而是text类型
    • 问题二:父亲组件可以拿到数据吗
    • 问题三:class组件怎么拿数据(点击👇🔗)


前言

1.Vue中的Provide和useContext(相同点)

1.主要都是为了解决传值问题出现的

2.主要用于 👴==》 👨 ==》孩子组件的传值问题,解决开发者从爷爷到孩子组件的 两次props的复杂传值问题

2…Vue中的Provide和useContext(不同点)

1.使用的方法不同(vue中的更加简单)

2.使用的方式不同(useContext相当于是爷爷组件的所有子组件都可以访问到传下来的数据。


一、useContext的用法(贼简单,自己看官网还容易看不懂)

第一步:创建传值的组件结构(爷爷,父亲,孩子组件)

1.说明如下:

这里主要是 爷爷组件导入了 父亲组件父亲组件导入了 孩子组件 所以就形成了一个三级嵌套的关系。 我们这时候 爷爷传给父就可以用props传值,传给孩子可以使用context进行传值

2.结构如下图:

在这里插入图片描述

第二步:创建Context(一定要导出)

代码如下

export const MyContext = React.createContext('link')

第三步:书写传值姿势

//这里的Value就是传给下面的值

    <MyContext.Provider value={buttonType as any}>
            <FatherComponent></FatherComponent>
    </MyContext.Provider>

第四步:导入useContext(一定是函数组件)

如果这里传的组件不是【函数组件】就不要使用 useContext去接受,
可以考虑使用consumer 或者 staic contype去接受 或者直接把类组件中的contype进行更改

child组件代码如下

import  React, { useContext } from "react";
import './index'
import { MyContext } from "../../../../App";
import { Button } from "antd";


export default function Child(props:any){

   const type = useContext(MyContext) as any; 
   console.log(type);
   
   
   return <div>
      <Button type={type.type}>child按钮</Button>
   </div>
}

说明如下图

在这里插入图片描述

第五步:查看传值结果

默认Text按钮

在这里插入图片描述

修改成Primary类型按钮

在这里插入图片描述


二、如何修改context的值(相当于是多传了一个修改函数)

1.修改索引(代码如下)

//修改了下面的这个Value值(改成了数组)。 //索引1是对应的一个类型,索引2表示的是修改当前type的方法


 <MyContext.Provider value={[buttonType,setButtonType] as any}>
            <FatherComponent></FatherComponent>
          </MyContext.Provider>

2.在child中添加一行代码,调用传下去的函数(一定要传修改的参数!)

  type[1]({ type: 'text' })

总结:⚠️重点注意(我踩的坑)

提示:这里对文章进行总结:

问题一:为什么第一次渲染的时候不是link类型,而是text类型

只有当组件所处的树中没有匹配到 Provider 时,其 defaultValue 参数才会生效 此默认值有助于在不使用 Provider 包装组件的情况下对组件进行测试。注意:将 undefined 传递给 Provider 的 value 时,消费组件的 defaultValue 不会生效。

问题二:父亲组件可以拿到数据吗

通过相同的使用方式,父组件也是可以拿到context向下传递的数据已经测试过了!!!!!

问题三:class组件怎么拿数据(点击👇🔗)

React中的 context 在class组件中如何接收传递数据

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

大数据Hadoop教程-学习笔记02【Apache Hadoop、HDFS】

视频教程&#xff1a;哔哩哔哩网站&#xff1a;黑马大数据Hadoop入门视频教程教程资源&#xff1a;https://pan.baidu.com/s/1WYgyI3KgbzKzFD639lA-_g 提取码: 6666【P001-P017】大数据Hadoop教程-学习笔记01【大数据导论与Linux基础】【P018-P037】大数据Hadoop教程-学习笔记0…

0301微分中值定理-微分中值定理与导数的应用

文章目录1 罗尔定理2 拉格朗日定理3 柯西中值定理5后记1 罗尔定理 费马引理 设函数f(x)在点x0f(x)在点x_0f(x)在点x0​的某邻域U(x0)U(x_0)U(x0​)内有定义&#xff0c;并且在点x0x_0x0​处可导&#xff0c;如果对任意的x∈U(x0),x\in U(x_0),x∈U(x0​),有 f(x)≤f(x0)(或f(x)…

给你的Vim加上自动编程功能

Vim 是高度可定制、可扩展的编辑器。这对热爱折腾的程序员来说&#xff0c;绝对是一种乐趣&#xff0c;同时也是进一步提升开发效率的源泉。近期CodeGeeX举办的黑客松活动中&#xff0c;参赛选手Lance 提交了一款名叫Vim with CodeGeeX的作品&#xff0c;这款作品是基于CodeGee…

Java开源工具库使用之httpclient

文章目录前言一、简单使用1.1 get 请求1.2 post 简单表单请求1.3 表单上传文件1.4 上传 json 数据二、高级用法2.1 超时和重试2.2 Cookie2.3 拦截器2.4 fluent API三、3.1旧版本使用3.1 Get 请求3.2 Post 请求四、异步版本使用4.1 基本请求4.2 请求流水线执行参考前言 HttpCli…

SSM SpringBoot vue 健康医疗预约系统

SSM SpringBoot vue 健康医疗预约系统 SSM 健康医疗预约系统 功能介绍 首页 图片轮播展示 出诊信息推荐 医院公告 科室信息 科室详情 出诊信息 医生详情 挂号预约 登录注册 留言反馈 个人中心 我的收藏 后台管理 登录 注册医生 个人中心 用户管理 科室信息管理 医生管理 出诊…

二、Java虚拟机的基本结构

Java虚拟机的架构1.内存结果概述2.类加载器子系统的作用3. 类加载器ClassLoader角色4.类的加载过程5.类加载器的分类1.引导类加载器(虚拟机自带的加载器)Bootstrap ClassLoader2.扩展类加载器(虚拟机自带的加载器) Extenssion ClassLoader3.应用程序类加载器(虚拟机自带的加载器…

CAN TP层函数介绍

如果想使用CAN TP层函数,首先需要在网络节点或测试节点配置页面的Componets组件一栏添加osek_tp.dll文件。路径为:C:\Program Files\Vector CANoe 15\Exec32 至于节点的CAPL程序内需不需要引用这个dll文件,无所谓,可写可不写。但是如果是其他dll,必须在CAPL程序中引用。为…

多服务器节点访问解决一人一单问题+redis设置锁方案

项目地址及项目具体介绍-码云仓库&#xff1a;https://gitee.com/flowers-bloom-is-the-sea/distributeNodeSolvePessimisticLockByRedis 测试1&#xff1a; 这里使用jmeter同时启动2各线程&#xff1a; 原来的数据库表的数据&#xff1a; goods的数据是&#xff1a; id …

金蝶云星空物料批量禁用反禁用程序

【需求描述】&#xff1a;需要通过批量禁用反禁用操作物料。 【操作方法】&#xff1a; 下载附件批量禁用程序。 首先双击安装&#xff0c;一直下一步。 双击打开 会提示需要配置账套信息 点击菜单栏配置 输入相关配置信息 填写完毕后 然后点击下载模板导入要下载的数据 选…

Linux进程学习【三】

✨个人主页&#xff1a; Yohifo &#x1f389;所属专栏&#xff1a; Linux学习之旅 &#x1f38a;每篇一句&#xff1a; 图片来源 &#x1f383;操作环境&#xff1a; CentOS 7.6 阿里云远程服务器 Perseverance is not a long race; it is many short races one after another…

Word控件Spire.Doc 【Table】教程(18):如何在 C# 中的 Word 中创建嵌套表格

Spire.Doc for .NET是一款专门对 Word 文档进行操作的 .NET 类库。在于帮助开发人员无需安装 Microsoft Word情况下&#xff0c;轻松快捷高效地创建、编辑、转换和打印 Microsoft Word 文档。拥有近10年专业开发经验Spire系列办公文档开发工具&#xff0c;专注于创建、编辑、转…

「JVM 编译优化」即时编译器

前端编译器&#xff08;javac&#xff09;将 Java 代码转为字节码&#xff08;抽象语法树&#xff09;&#xff0c;优化手段主要用于提升程序的编码效率&#xff1b; 后端编译器&#xff08;内置于 JVM 的 JIT/AOT Compiler&#xff0c;C1&#xff0c;C2&#xff09;将字节码转…

2022年休闲游戏市场总结

在预测 2023 年之前&#xff0c;我们先回顾一下 2022 年。从上一年发生的事件中往往能看到未来趋势的影子&#xff0c;所以 2022 年的总结至关重要。一、2022年总结回顾1、流行游戏类型回顾 2022 年&#xff0c;三种超休闲游戏表现最为突出&#xff1a;跑酷游戏&#xff1a;跑酷…

spring之声明式事务开发

文章目录一、声明式事务之全注解式开发1、新建springConfig类2、测试程序3、测试结果二、声明式事务之XML实现方式1、配置步骤2、测试程序3、运行结果附一、声明式事务之全注解式开发 基于之前的银行转账系统&#xff0c;将spring.xml配置文件嘎掉&#xff0c;变成全注解式开发…

【极海APM32替代笔记】低功耗模式下的RTC唤醒(非闹钟唤醒,而是采用RTC_WAKEUPTIMER)

【极海APM32替代笔记】低功耗模式下的RTC唤醒&#xff08;非闹钟唤醒&#xff0c;而是采用RTC_WAKEUPTIMER&#xff09; 【STM32笔记】低功耗模式配置及避坑汇总 前文&#xff1a; blog.csdn.net/weixin_53403301/article/details/128216064 【STM32笔记】HAL库低功耗模式配置…

Spring Boot整合RabbitMQ教程

1.首页我们了解一下消息中间件的应用场景异步处理场景说明&#xff1a;用户注册后&#xff0c;需要发注册邮件和注册短信,传统的做法有两种1.串行的方式;2.并行的方式 (1)串行方式:将注册信息写入数据库后,发送注册邮件,再发送注册短信,以上三个任务全部完成后才返回给客户端。…

js实现轮播图

实现的效果图 原理:一次性加载所有图片&#xff0c;使用定位将图片重合在一起&#xff0c;根据opacity&#xff0c;z-index 属性显示当前图片 一、基本的HTML布局 创建一个外部容器来存放图片&#xff0c;prev-next是添加的左右切换按钮&#xff0c;dot存放图片下方的小白点…

《爆肝整理》保姆级系列教程python接口自动化(二十一)--unittest简介(详解)

简介 前边的随笔主要介绍的requests模块的有关知识个内容&#xff0c;接下来看一下python的单元测试框架unittest。熟悉 或者了解java 的小伙伴应该都清楚常见的单元测试框架 Junit 和 TestNG&#xff0c;这个招聘的需求上也是经常见到的。python 里面也有单元 测试框架-unitt…

小熊电器:精品与创意,走上“顶流之路”的两把“宝剑”

回顾2022年&#xff0c;小家电市场降温趋势明显&#xff0c;业绩表现整体低迷&#xff0c;如主打高端路线的北鼎&#xff0c;去年8亿元的营收出现个位数下滑&#xff0c;归母净利润同比下降超56%&#xff1b;苏泊尔营收也出现微降&#xff0c;归母净利润预计同比增长不到10%。而…

教你如何搭建培训机构-招生管理系统,demo可分享

1、简介1.1、案例简介本文将介绍&#xff0c;如何搭建培训机构-招生管理。1.2、应用场景根据意向信息站的收录信息&#xff0c;可批量导入意向信息&#xff0c;在意向信息站转为意向学员&#xff0c;转为意向学员后可进行报名收费成为正式学员。2、设置方法2.1、表单搭建1&…