-
一般用于【祖组件】与【后代组件】间通信
案例:
A,B,C,D四个组件的关系分别为:爷爷,爸爸,儿子,孙子
从A向C传递参数:C组件为类式组件
从A向D传递参数:D组件为函数组件
javascriptimport React, { Component } from 'react' import './index.css' /** * 【祖组件】与【后代组件】间通信 */ // 创建Context容器对象: const MyContext = React.createContext() const {Provider,Consumer} = MyContext export 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 { // 第一步:声明接受context static 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> ) }样式文件:
javascript.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; }运行效果:

react组件间通信之context
种草小幺儿.2023-11-09 8:31
相关推荐
GISer_Jing3 分钟前
今天看了京东零售JDS的保温直播,秋招,好像真的结束了,接下来就是论文+工作了!!!加油干论文,学&分享技术Mapmost10 分钟前
【高斯泼溅】如何将“歪头”的3DGS模型精准“钉”在地图上,杜绝后续误差?废春啊42 分钟前
前端工程化爱上妖精的尾巴43 分钟前
6-9 WPS JS宏Map、 set、get、delete、clear()映射的添加、修改、删除爱分享的鱼鱼1 小时前
对比理解 Vue 响应式 API:data(), ref、reactive、computed 与 watch 详解JS_GGbond1 小时前
【性能优化】给Vue应用“瘦身”:让你的网页快如闪电的烹饪秘籍T___T1 小时前
一个定时器,理清 JavaScript 里的 this代码小学僧1 小时前
从 Arco Table 迁移到 VTable:VTable使用经验分享微笑的曙光1 小时前
Vue3 环境搭建 5 步走(零基础友好)不知名用户来了1 小时前
基于vue3 封装的antdv/element-Plus 快速生成增删改查页面