react路由中使用context

Context(类似 Vue 的 provide/inject,适合中等规模)

复制代码
// 创建 Context
const ThemeContext = React.createContext<'light' | 'dark'>('light');

// 提供者
function App() {
  const [theme, setTheme] = useState<'light'|'dark'>('light');
  return (
    <ThemeContext.Provider value={theme}>
      <Toolbar />
    </ThemeContext.Provider>
  );
}

// 消费者(在任意子组件)
function Toolbar() {
  const theme = useContext(ThemeContext);
  return <div>Current theme: {theme}</div>;
}

详细介绍一下context 使用方法

第一步:将 Context 定义在一个单独的文件(或至少导出)

复制代码
// contexts/ThemeContext.tsx
import { createContext } from 'react';

export const ThemeContext = createContext<'light' | 'dark'>('light');

第二步:在 App 中导入 Provider 并包裹路由

复制代码
// App.tsx
import { BrowserRouter, Routes, Route, Link } from 'react-router-dom';
import { ThemeContext } from './contexts/ThemeContext';
import Home from './pages/home';
import About from './pages/About';
import UserDetail from './pages/userDetail';

function App() {
  const [theme, setTheme] = useState<'light'|'dark'>('light');
  return (
    <BrowserRouter>
      <ThemeContext.Provider value={theme}>
        <nav>
          <Link to="/">Home</Link>
          <Link to="/about">About</Link>
        </nav>
        <Routes>
          <Route path="/" element={<Home />} />
          <Route path="/about" element={<About />} />
          <Route path="/user/:id" element={<UserDetail />} />
        </Routes>
      </ThemeContext.Provider>
    </BrowserRouter>
  );
}

第三步:在任意路由组件中导入并使用同一个 Context

复制代码
// pages/home.tsx
import { useContext } from 'react';
import { ThemeContext } from '../contexts/ThemeContext';

export default function Home() {
  const theme = useContext(ThemeContext);
  return <div>Home - current theme: {theme}</div>;
}

// pages/userDetail.tsx
import { useContext } from 'react';
import { useParams } from 'react-router-dom';
import { ThemeContext } from '../contexts/ThemeContext';

export default function UserDetail() {
  const { id } = useParams();
  const theme = useContext(ThemeContext);
  return (
    <div>
      User ID: {id} <br />
      Theme: {theme}
    </div>
  );
}

常见错误与检查清单

错误现象 可能原因 解决方法
useContext(ThemeContext) 返回默认值 'light',修改 Provider 的 value 也没用 你在组件中导入的 ThemeContext 和 Provider 使用的不是同一个对象(比如从不同文件导出了两个不同的 Context) 确保整个应用只定义一次 createContext,并且所有地方都从同一个文件导入
报错 ThemeContext is not defined 没有导入 Context 在需要使用 useContext 的文件里 import { ThemeContext } from '...'
Context 值变化了,但某些路由组件没有更新 可能是路由组件被 React.memo 包裹,或者你在 Provider 外面使用了 BrowserRouter 导致 Context 没有包裹到该路由 ThemeContext.Provider 放在 BrowserRouter 内部 (但包裹住 Routes 就行,你原来的位置是对的)
UserDetail 组件中 useParams() 拿不到 id 路由配置错误:<Route path="/user/:id" element={<UserDetail />} /> 必须正确,且 UserDetail 必须是在 <Routes> 内渲染的组件,不能是嵌套在 App 内部的函数 UserDetail 提取为单独的文件或至少定义在 App 外部

总结

  • Context 在路由组件 ,只要 Provider 包裹了 <Routes>

  • 关键点:同一个 Context 对象必须被所有使用它的组件导入。

  • 如果你按文件拆分,记得 exportimport

相关推荐
小雨下雨的雨1 小时前
井字棋AI机器人实现详解 - Minimax算法实战-鸿蒙PC Electron框架完成
前端·人工智能·算法·华为·electron·鸿蒙
ZC跨境爬虫5 小时前
跟着 MDN 学JavaScript day_7:数学运算与逻辑判断实战测试
开发语言·前端·javascript·学习·ecmascript
fangdengfu1235 小时前
ES分析系统各个服务日志占用量
java·前端·elasticsearch
凌云拓界5 小时前
文件管理:让AI安全操作你的电脑 ——CogitoAgent开发实战(三)
javascript·人工智能·架构·开源·node.js
凌云拓界6 小时前
联网能力:让AI看见更广阔的世界 ——CogitoAgent开发实战(四)
javascript·人工智能·架构·node.js·创业创新
JustHappy6 小时前
古法编程秘籍(六):程序到底是怎么跑起来的?从 IO 到中断,一次讲明白
前端·后端·全栈
HYCS7 小时前
用pixi.js实现fabric.js(六):从线性代数的角度理解编辑器交互
前端·javascript·canvas
卷帘依旧7 小时前
useImperativeHandle的作用
前端
卷帘依旧7 小时前
Hooks在Fiber上的存储原理
前端