您当前的位置:首页 > 网站建设 > javascript
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax | jQuery | 小程序 |

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

51自学网 2022-02-21 13:39:20
  javascript

该功能实现效果类似于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多组件传值内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net!


下载地址:
jQuery实现表单验证功能
前端JavaScript之Promise
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。