Context是如何进行多组件传值的,过程是怎样
Admin 2022-07-01 群英技术资讯 583 次浏览
该功能实现效果类似于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> ); }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
目录引言class 第一个好:私有变量class 第二个好:super 继承引言在很早以前,写过一篇文章 “类”设计模式和“原型”设计模式——“复制”和“委托”的差异 ,大致意思就是说:代码复用,也就是继承、重写,有两种思路:1. 面向对象的类继承;2. 基于 JavaScript 原型链的原型继承;前者的主要特点是:
NgModule 模块是Angular种一个重要的点,因为Angular的基本构造块就是NgModule。本篇文章就来带大家了解一下Angular中的NgModule模块,希望对大家有所帮助!
这篇文章主要介绍了在vue中使用vant TreeSelect分类选择组件操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
我们在用电脑浏览一些商城网站的时候,将鼠标移至商品图片就有放大查看细节的功能,很多朋友比较好奇这样放大镜的功能是怎样实现的,因此这篇文章就主要给大家分享用JS实现放大镜查看商品细节功能,实现效果的代码如下:
如何理解JS变量的可及性,相关知识有哪些?在JavaScript开发中一直是由变量构成的,而这个变量是由多个数据组成的,下面小编将和大家一起介绍探讨关于JS变量的可及性,希望对你学习这方面知识有所帮助。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008