Context是如何进行多组件传值的,过程是怎样
今天这篇给大家分享的知识是“Context是如何进行多组件传值的,过程是怎样”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“Context是如何进行多组件传值的,过程是怎样”文章能帮助大家解决问题。
到此这篇关于“Context是如何进行多组件传值的,过程是怎样”的文章就介绍到这了,更多相关Context是如何进行多组件传值的,过程是怎样内容,欢迎关注博信技术资讯频道,小编将为大家输出更多高质量的实用文章!
该功能实现效果类似于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> ); }
到此这篇关于“Context是如何进行多组件传值的,过程是怎样”的文章就介绍到这了,更多相关Context是如何进行多组件传值的,过程是怎样内容,欢迎关注博信技术资讯频道,小编将为大家输出更多高质量的实用文章!
版权声明
本文仅代表作者观点,不代表博信信息网立场。
上一篇:Karkinos是什么 下一篇:DIY香港服务器:打造高效稳定的网络环境