React通过conetxt实现多组件传值功能
更新时间:2021年10月21日 14:29:11 作者:明知山_
Context 提供了一种在组件之间共享此类值的方式,而不必显式地通过组件树的逐层传递 props。本文给大家介绍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>
);
}
到此这篇关于React通过conetxt实现多组件传值的文章就介绍到这了,更多相关React多组件传值内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
React Hooks useReducer 逃避deps组件渲染次数增加陷阱
这篇文章主要介绍了React Hooks 之 useReducer 逃避deps后增加组件渲染次数的陷阱详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-09-09
简析React Native startReactApplication 方法
这篇文章主要介绍了React Native startReactApplication 方法简析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-09-09
react中history(push,go,replace)切换路由方法的区别及说明
这篇文章主要介绍了react中history(push,go,replace)切换路由方法的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-10-10


最新评论