当前位置: 首页 > news >正文

react组件间通信之context

  • 一般用于【祖组件】与【后代组件】间通信

    案例:

    A,B,C,D四个组件的关系分别为:爷爷,爸爸,儿子,孙子
    从A向C传递参数:C组件为类式组件
    从A向D传递参数:D组件为函数组件

    import React, { Component } from 'react'
    import './index.css'/*** 【祖组件】与【后代组件】间通信*/// 创建Context容器对象:
    const MyContext = React.createContext()
    const {Provider,Consumer} = MyContextexport default class A extends Component {state = {name:'sun',age:18}render() {const {name,age} = this.state;return (<div className='one'><h5>A组件</h5><div>我的名字是:{name}</div>{/* 渲染子组件时,外面包裹Provider,通过value属性给后代组件传递参数 */}<Provider value={{name,age}}><B></B></Provider></div>)}
    }class B extends Component {render() {return (<div className='two'><h5>B组件</h5><C></C></div>)}
    }/*** 后代组件读取数据* 方式一:仅使用于类组件*/
    class C extends Component {// 第一步:声明接受contextstatic contextType = MyContext;render() {return (<div className='three'><h5>C组件</h5>{/* 第二步:读取context中的value数据 */}<div>C组件从A组件拿到的名字是:{this.context.name}</div>        <D></D></div>)}
    }/*** 后代组件读取数据* 方式二:函数组件与类组件都可以*/
    function D(){return(<div className='four'><h5>D组件</h5><div>D组件从A组件拿到的名字是:<Consumer>{value => `${value.name},年龄是:${value.age}`}</Consumer></div></div>)
    }

    样式文件:

    .one{width: 500px;background-color: red;padding: 20px;
    }
    .two{width: 90%;background-color: orange;padding: 20px;
    }
    .three{width: 90%;background-color: yellow;padding: 20px;
    }
    .four{width: 90%;background-color: green;padding: 20px;
    }
    

    运行效果:
    在这里插入图片描述

http://www.lryc.cn/news/224416.html

相关文章:

  • 京东数据分析:2023年10月京东洗衣机行业品牌销售排行榜
  • QQ恢复聊天记录,就用这3个方法!
  • 高能数造电池3D打印智能制造小试线,开启全固态电池数字化新时代
  • stable diffusion为什么能用于文本到图像的生成
  • c语言刷题第10周(16~20)
  • Vue.js 响应式系统深度剖析
  • LabVIEW如何才能得到共享变量的引用
  • 界面控件DevExtreme图表和仪表(v23.1) - 新功能(Angular,React,Vue,jQuery)
  • Rust和isahc库编写代码示例
  • Win10笔记本开热点后电脑断网的解决方法
  • 跨链知识指南
  • 字符编码转换时发生内存越界引发的摄像头切换失败问题的排查
  • git修改之前的commit提交的作者信息和邮箱信息
  • 《视觉SLAM十四讲》-- 相机与图像
  • 欧科云链:成本与规模之辨——合规科技如何赋能香港Web3生态?
  • 【文献分享】NASA JPL团队CoSTAR一大力作:直接激光雷达里程计:利用密集点云快速定位
  • SPASS-探索性分析
  • 电子印章怎么弄?三步教你电子印章在线生成免费教程!
  • 以技术创新引领行业发展,飞凌嵌入式获双项省级荣誉
  • 在Google Kubernetes集群创建分布式Jenkins(二)
  • GEE:GEE中调用 Math.js 教程
  • 迅为龙芯3A5000主板,支持PCIE 3.0、USB 3.0和 SATA 3.0显示接口2 路、HDMI 和1路 VGA,可直连显示器
  • Opencv for unity 下载
  • 独立IP主机怎么样?对网站有什么影响
  • Gerrit lfs安装及配置
  • 基于表面电势的AlGaN/GaN MODFET紧凑模型
  • c语言中的fread
  • Unity游戏开发基础组件
  • 股票四倍杠杆什么意思?
  • 【hcie-cloud】【2】华为云Stack解决方案介绍、缩略语整理 【下】