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;
    }

    运行效果:

相关推荐
anOnion1 小时前
构建无障碍组件之Slider Pattern
前端·html·交互设计
云水一下1 小时前
JavaScript 从零基础到精通系列:前世今生与编程启蒙
前端·javascript
月亮邮递员6161 小时前
Markdown语法总结
开发语言·前端·javascript
Kurisu5751 小时前
雾锁王国修改器下载2026最新
前端·修改器代码
Rain5091 小时前
mini-cc 的 MCP 协议:给 AI 装个 USB-C 接口
c语言·开发语言·前端·人工智能·架构·node.js·ai编程
向量引擎2 小时前
从零起步,如何打造专属向量引擎 API 中转工作流?
java·服务器·前端
IT_陈寒3 小时前
Vue这个动态响应坑把我整不会了
前端·人工智能·后端
bestlanzi3 小时前
使用nvm管理node环境
前端·vue.js·npm
SomeOtherTime3 小时前
Geojson相关(AI回答)
java·前端·python
就叫_这个吧4 小时前
HTML常用标签及举例使用
前端·html