React多组件传值 React通过conetxt实现多组件传值功能
明知山_ 人气:0想了解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> ); }
加载全部内容