react hooks的useContext

简介:

React 的 useContext Hook 用于在函数组件中获取上下文(Context)的值。它允许我们在组件中订阅并访问由 React 的 Context API 提供的值。

首先,我们需要创建一个上下文对象。上下文对象被创建时,它包含一个 Provider 和一个 Consumer。

在创建上下文对象后,我们可以使用 useContext Hook 在函数组件中订阅上下文的值。

以下是使用 useContext Hook 的一般步骤:

  1. 创建上下文对象:

    import React, { createContext } from 'react';

    // 创建上下文对象
    const MyContext = createContext();

  2. 在顶层组件中通过 Provider 提供上下文的值:

    import React from 'react';
    import { MyContext } from './MyContext';

    function App() {
    return (
    // 使用 Provider 提供上下文的值
    <MyContext.Provider value="Hello, World!">
    <ChildComponent />
    </MyContext.Provider>
    );
    }

  3. 在子组件中使用 useContext Hook 获取上下文的值:

    import React, { useContext } from 'react';
    import { MyContext } from './MyContext';

    function ChildComponent() {
    // 使用 useContext Hook 获取上下文的值
    const contextValue = useContext(MyContext);

    return

    {contextValue}
    ;
    }

在上面的示例中,我们首先创建了一个名为 MyContext 的上下文对象,并将其导出供其他组件使用。

然后,在根组件 App 中,我们使用 MyContext.Provider 组件提供上下文的值,并将要共享的值传递给 value 属性。

最后,在子组件 ChildComponent 中,我们使用 useContext Hook 来接收 MyContext 上下文对象的值,并将其赋值给 contextValue 变量。然后,我们可以在组件中使用这个值。

需要注意的是,useContext Hook 接收一个上下文对象作为参数,并返回上下文的当前值。它只能在函数组件的顶层中使用,而不能在嵌套的函数或类中使用。

当上下文的值发生变化时,使用 useContext Hook 的组件会自动重新渲染。这使得我们可以便捷地使用 React 的 Context API 来共享和订阅全局状态。

全部代码:

复制代码
import React, { createContext, useContext } from 'react';
// 使用 useContext 函数可以避免在组件层层传递 props,从而简化了组件之间的数据共享。
// 创建一个 Context 对象
const MyContext = createContext();

// 在组件树中的某个位置提供 Context 的值
function MyProvider(props) {
    const contextValue = {...props.student};

    return <MyContext.Provider value={contextValue}>{props.children}</MyContext.Provider>;
}
function Bag() {
    const contextValue = useContext(MyContext);

    return (
        <div>
            <p>Bag: {contextValue.bag}</p>
        </div>
    );
}
// 使用 useContext 来使用 Context 中的值
function MyComponent() {
    const contextValue = useContext(MyContext);

    return (
        <div>
            <p>Name: {contextValue.name}</p>
            <p>Age: {contextValue.age}</p>
            <Bag></Bag>
        </div>
    );
}

// 在组件中使用 Context
export default function App() {
    const [state, setState] = React.useState({
        name: 'Tom',
        age: 18,
        bag: '两本书 一壶水'
    });
    return (
        <MyProvider student={state}>
            <MyComponent />
        </MyProvider>
    );
}
相关推荐
魔云连洲3 分钟前
Vue的响应式底层原理:Proxy vs defineProperty
前端·javascript·vue.js
专注VB编程开发20年6 分钟前
CSS定义网格的列模板grid-template-columns什么意思,为什么要用这么复杂的单词
前端·css
IT_陈寒12 分钟前
Redis性能提升50%的7个关键优化策略,90%开发者都不知道第5点!
前端·人工智能·后端
Hilaku19 分钟前
深入URL和URLSearchParams:别再用正则表达式去折磨URL了
前端·javascript·代码规范
pubuzhixing24 分钟前
Canvas 的性能卓越,用它解决一个棘手问题
前端
weixin_4569042725 分钟前
Vue.jsmain.js/request.js/user.js/store/index.js Vuex状态管理项目核心模块深度解析
前端·javascript·vue.js
伍哥的传说28 分钟前
Vue 3.6 Alien Signals:让响应式性能飞跃式提升
前端·javascript·vue.js·vue性能优化·alien-signals·细粒度更新·vue 3.6新特性
永日4567032 分钟前
学习日记-HTML-day51-9.9
前端·学习·html
狗头大军之江苏分军1 小时前
iPhone 17 vs iPhone 17 Pro:到底差在哪?买前别被忽悠了
前端
小林coding1 小时前
再也不怕面试了!程序员 AI 面试练习神器终于上线了
前端·后端·面试