react多级组件间如何传递props

1.使用props属性一级级传递

针对父,子,孙子,如何实现将props从父级传递给孙子。

父:

javascript 复制代码
<ParentComponent parent={this} /> //传递this

子:

javascript 复制代码
<childComponent propsContext={this.props.parent} />

孙子:

javascript 复制代码
getProps() {
	return this.props.propsContext  //使用父组件传递来的props
}

2.使用API Context

使用 Context 可以更方便地跨多层级组件传递数据,而不需要手动逐层传递 props。

使用方法:

1)创建 Context

首先,需要在一个单独的文件中创建 Context 对象。

javascript 复制代码
// MyContext.js
import React from 'react';

const MyContext = React.createContext();
export default MyContext;

2)提供数据的组件

在一个父组件中使用 MyContext.Provider 提供数据。

javascript 复制代码
// ParentComponent.js
import React from 'react';
import MyContext from './MyContext';

class ParentComponent extends React.Component {
  render() {
    const someData = "Hello from Context";

    return (
      <MyContext.Provider value={someData}>
        {this.props.children}
      </MyContext.Provider>
    );
  }
}

export default ParentComponent;

3)接收数据的组件

这种方法只适用于单个 Context,并且只能在类组件中使用, 使用 contextType 可以让 this.context 直接获取到 Context 的值,但是这个类只能订阅一个 Context。

(如果有多个 Context 需要在同一个类组件中使用,可以通过多次使用 MyContext.Consumer 或者多个 contextType 静态属性来处理每个 Context 的值)

javascript 复制代码
import React from 'react';
import MyContext from './MyContext';

class ChildComponent extends React.Component {
  static contextType = MyContext;

  render() {
    const value = this.context;

    return (
      <div>
        <p>{value}</p>
      </div>
    );
  }
}

export default ChildComponent;
相关推荐
天平2 小时前
油猴脚本创建webworker踩坑记录
前端·javascript·typescript
原则猫4 小时前
前端基础大厦
前端
陈随易5 小时前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart6 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒8 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰8 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
山河木马8 小时前
渲染管线-计算得到gl_Position(顶点着色器)之后续GPU流程
javascript·webgl·图形学
竹林8189 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花9 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu122710 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude