React的基础知识:Context

1. Context

在 React 中,Context 提供了一种通过组件树传递数据的方式,无需手动在每个层级传递 props。这在处理一些全局应用状态时非常有用,比如用户认证、主题、语言偏好等。

  1. 如何使用 Context
    创建 Context:首先,你需要使用 React.createContext 创建一个新的 Context 对象。
javascript 复制代码
const MyContext = React.createContext(defaultValue);

这里的 defaultValue 是当组件没有被任何 Provider 包裹时,消费组件(Consumer)会使用的值。

  1. 提供 Context 值:使用 <Context.Provider> 组件来包裹你的组件树,以便提供 Context 值。
java 复制代码
<MyContext.Provider value={/* 一些值 */}>
  <ChildComponent />
</MyContext.Provider>

value 属性可以是任何你想要传递给消费组件的数据,它可以是一个对象,也可以是一个函数。

  1. 消费 Context 值
    使用 useContext Hook:useContext 是一个 Hook,它允许函数组件直接订阅 Context 的变化。
javascript 复制代码
const value = useContext(MyContext);

示例

以下是一个简单的 Context 示例,展示了如何创建和使用 Context 来共享一个主题颜色。

javascript 复制代码
// 创建 Context
const ThemeContext = React.createContext('light');

// 提供 Context 值
function App() {
  return (
    <ThemeContext.Provider value="dark">
      <Toolbar />
    </ThemeContext.Provider>
  );
}

// 消费 Context 值
function Toolbar() {
  return (
    <div>
      <ThemeButton />
    </div>
  );
}

function ThemeButton() {
  const theme = useContext(ThemeContext);
  return <button>{theme === 'dark' ? 'Light' : 'Dark'}</button>;
}

在这个例子中,ThemeContext 被用来在 App 组件和 ThemeButton 组件之间共享当前的主题颜色。App 组件通过 ThemeContext.Provider 提供了主题颜色的值,而 ThemeButton 组件使用 useContext Hook 来消费这个值。

相关推荐
一起养小猫5 分钟前
Flutter for OpenHarmony 实战:ListView与GridView滚动列表完全指南
开发语言·javascript·flutter
熊猫钓鱼>_>13 分钟前
从零到一:打造“抗造” Electron 录屏神器的故事
前端·javascript·ffmpeg·electron·node·录屏·record
晚霞的不甘30 分钟前
Flutter for OpenHarmony《智慧字典》 App 主页深度优化解析:从视觉动效到交互体验的全面升级
前端·flutter·microsoft·前端框架·交互
我是伪码农33 分钟前
Vue 1.28
前端·javascript·vue.js
鹓于37 分钟前
Excel一键生成炫彩二维码
开发语言·前端·javascript
siwangdexie_new37 分钟前
html格式字符串转word文档,前端插件( html-docx-js )遇到兼容问题的解决过程
前端·javascript·html
子春一1 小时前
Flutter for OpenHarmony:构建一个智能长度单位转换器,深入解析 Flutter 中的多字段联动、输入同步与工程化表单设计
开发语言·javascript·flutter
2601_949613021 小时前
flutter_for_openharmony家庭药箱管理app实战+用药提醒列表实现
服务器·前端·flutter
利刃大大1 小时前
【Vue】scoped作用 && 父子组件通信 && props && emit
前端·javascript·vue.js
-凌凌漆-1 小时前
【Vue】Vue3 vite build 之后空白
前端·javascript·vue.js