react18【系列实用教程】useContext —— Context 机制实现越层组件传值 (2024最新版)

什么是 Context 机制?

Context 机制是 react 实现外层组件向内层组件传值的一种方案,父组件可以向其内部的任一组件传值,无论是子组件还是孙组件或更深层次的组件。

实现步骤

1.使用createContext方法创建一个上下文对象 Ctx

2.在顶层组件中通过Ctx.Provider 组件提供数据

3.在底层组件中通过 useContext 钩子函数获取数据

范例

context.js

创建独立的 context 文件,并导出createContext方法创建的上下文对象 data_context

js 复制代码
import { createContext } from "react";
// 通过传参可以指定默认值
export const data_context = createContext("默认值");

father.jsx

  • 导入上下文对象 data_context
  • data_context.Provider 标签包裹需要传值的内部组件
  • 用 value 属性传值
js 复制代码
import Child from "./child.jsx";
import "./common.css";
import { data_context } from "./context.js";

function Father() {
  const fatherData = "父组件的数据";
  return (
    <>
      <div className="box" style={{ width: "400px" }}>
        <h1>我是父组件</h1>
        <data_context.Provider value={fatherData}>
          <Child />
        </data_context.Provider>
      </div>
    </>
  );
}

export default Father;

common.css

css 复制代码
.box {
    border: 1px solid;
    padding: 20px;
}

child.jsx

js 复制代码
import GrandChild from "./grandchild.jsx";
function Child() {
  return (
    <>
      <div className="box">
        <h1>我是子组件</h1>
        <GrandChild />
      </div>
    </>
  );
}

export default Child;

grandchild.jsx

  • 导入 useContext 和 上下文对象 data_context
  • 调用 useContext 获取数据,参数为上下文对象 data_context
js 复制代码
import { useContext } from "react";
import { data_context } from "./context.js";

function GrandChild() {
  const dataFromGrandfather = useContext(data_context);
  return (
    <>
      <div className="box">
        <h1>我是孙组件</h1>
        <p>父组件传来的数据为:{dataFromGrandfather}</p>
      </div>
    </>
  );
}

export default GrandChild;
相关推荐
柯北(jvxiao)5 天前
Vue vs React 多维度剖析: 哪一个更适合大型项目?
前端·vue·react
袋鼠云数栈前端6 天前
扣子 Coze 产品体验功能
大数据·ai·react
想你依然心痛11 天前
React 表单处理:移动端输入场景下的卡顿问题与防抖优化方案
react
亦世凡华、16 天前
React--》实现 PDF 文件的预览操作
经验分享·pdf·react·pdf预览
技术路上的探险家17 天前
Web3:在 VSCode 中使用 Vue 前端与已部署的 Solidity 智能合约进行交互
vscode·web3·区块链·交互·react·solidity·ethers.js
友莘居士22 天前
Dify中的Agent和发现和调用mcp工具两个节点调用的异同
agent·react·dify·functioncalling·mcp
aiguangyuan23 天前
前端开发性能优化概要
系统架构·vue·react·前端开发
叶 落1 个月前
Component cannot be used as a JSX component
typescript·react
小浣熊喜欢揍臭臭1 个月前
react+antd+表格拖拽排序以及上移、下移、移到顶部、移到底部
前端·前端框架·react
小浣熊喜欢揍臭臭1 个月前
react+antd 可拖拽模态框组件
前端·javascript·react