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

发布时间:2022-04-16 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了React通过conetxt实现多组件传值功能脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

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

在这里插入图片描述

定义一个公共的文件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>
    );
}

到此这篇关于React通过conetxt实现多组件传值文章就介绍到这了,更多相关React多组件传值内容请搜索脚本宝典以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本宝典!

脚本宝典总结

以上是脚本宝典为你收集整理的React通过conetxt实现多组件传值功能全部内容,希望文章能够帮你解决React通过conetxt实现多组件传值功能所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:React