React多组件传值 React通过conetxt实现多组件传值功能

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

React多组件传值 React通过conetxt实现多组件传值功能

明知山_   2021-10-21 我要评论
想了解React通过conetxt实现多组件传值功能的相关内容吗,明知山_在本文为您仔细讲解React多组件传值的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:React多组件传值,React,conetxt,多组件传值,下面大家一起来学习吧。

该功能实现效果类似于vue的provide/inject
而React可通过context进行完成

在这里插入图片描述

定义一个公共的文件context/Theme.jsx

import { createContext } from 'react';
const theme = createContext()
export default theme

父组件引入公共文件及子组件
并传递theme值

import React, { useState } from 'react';
import Child from "@/components/Child.jsx"
import Theme from "@/context/Theme.jsx"
export default () => {
    const [theme, setTheme] = useState("blue")
    return (
        <>
            <button onClick={() => setTheme("green")}>检验context是否为响应式</button>
            <Theme.Provider value={theme}>
                <Child />
            </Theme.Provider>
        </>
    )
}

子组件获取数据components/Child.jsx

import React from 'react';
import Theme from "@/context/Theme.jsx"
export default () => {
    return (
        <Theme.Consumer>
            {data => <p>接收父组件context传递的值:{data}</p>}
        </Theme.Consumer>
    );
}

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们