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

    运行效果:

相关推荐
小远yyds14 分钟前
前端Web用户 token 持久化
开发语言·前端·javascript·vue.js
阿伟来咯~1 小时前
记录学习react的一些内容
javascript·学习·react.js
吕彬-前端1 小时前
使用vite+react+ts+Ant Design开发后台管理项目(五)
前端·javascript·react.js
学前端的小朱1 小时前
Redux的简介及其在React中的应用
前端·javascript·react.js·redux·store
guai_guai_guai1 小时前
uniapp
前端·javascript·vue.js·uni-app
bysking2 小时前
【前端-组件】定义行分组的表格表单实现-bysking
前端·react.js
王哲晓3 小时前
第三十章 章节练习商品列表组件封装
前端·javascript·vue.js
fg_4113 小时前
无网络安装ionic和运行
前端·npm
理想不理想v3 小时前
‌Vue 3相比Vue 2的主要改进‌?
前端·javascript·vue.js·面试
酷酷的阿云3 小时前
不用ECharts!从0到1徒手撸一个Vue3柱状图
前端·javascript·vue.js