react组件间通信之context

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

    案例:

    A,B,C,D四个组件的关系分别为:爷爷,爸爸,儿子,孙子

    从A向C传递参数:C组件为类式组件

    从A向D传递参数:D组件为函数组件

    javascript 复制代码
    import 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;
    }

    运行效果:

相关推荐
爱学习的小仙女!38 分钟前
面试题 前端(一)DOCTYPE作用 标准模式与混杂模式区分
前端·前端面试题
小小小小宇1 小时前
前端转后端基础- 变量和类型
前端
Cobyte2 小时前
1.基于依赖追踪和触发的响应式系统的本质
前端·javascript·vue.js
主宰者2 小时前
C# CommunityToolkit.Mvvm全局事件
java·前端·c#
前端小咸鱼一条3 小时前
16.迭代器 和 生成器
开发语言·前端·javascript
小江的记录本3 小时前
【注解】常见 Java 注解系统性知识体系总结(附《全方位对比表》+ 思维导图)
java·前端·spring boot·后端·spring·mybatis·web
web守墓人3 小时前
【前端】记一次将ruoyi vue3 element-plus迁移到arco design vue的经历
前端·vue.js·arco design
伊步沁心3 小时前
Webpack & Vite 深度解析
前端
libokaifa3 小时前
OpenSpec + TDD:让 AI 写代码,用测试兜底
前端·ai编程
用户15815963743703 小时前
搭 AI Agent 团队踩了 18 个坑,总结出这 5 个关键步骤
前端