【大前端】React 父子组件通信、子父通信、以及兄弟(同级)组件通信

在 React 中,组件之间的通信是核心问题之一。可以分为三类:父子组件通信子父通信 、以及兄弟(同级)组件通信。我给你梳理一下常见方式和对应示例:


一、父子组件通信

父组件通过 props 将数据或方法传递给子组件。

tsx 复制代码
// Parent.tsx
import React, { useState } from "react";
import Child from "./Child";

export default function Parent() {
  const [message, setMessage] = useState("Hello from Parent!");

  return <Child text={message} />;
}

// Child.tsx
import React from "react";

export default function Child({ text }: { text: string }) {
  return <h2>{text}</h2>;
}

👉 这是 React 中最常见的方式,数据单向流动。


二、子父组件通信(回调函数)

子组件通过调用父组件传递下来的 回调函数 来"通知"父组件。

tsx 复制代码
// Parent.tsx
import React, { useState } from "react";
import Child from "./Child";

export default function Parent() {
  const [msgFromChild, setMsgFromChild] = useState("");

  const handleChildMsg = (msg: string) => {
    setMsgFromChild(msg);
  };

  return (
    <div>
      <Child onSend={handleChildMsg} />
      <p>子组件发来的消息: {msgFromChild}</p>
    </div>
  );
}

// Child.tsx
import React from "react";

export default function Child({ onSend }: { onSend: (msg: string) => void }) {
  return (
    <button onClick={() => onSend("Hello Parent!")}>发送消息给父组件</button>
  );
}

三、同级组件通信(兄弟组件通信)

兄弟组件无法直接通信,需要通过共同的父组件全局状态管理 来中转。

方式 1:借助共同父组件

tsx 复制代码
// Parent.tsx
import React, { useState } from "react";
import ChildA from "./ChildA";
import ChildB from "./ChildB";

export default function Parent() {
  const [msg, setMsg] = useState("");

  return (
    <div>
      <ChildA onSend={setMsg} />
      <ChildB message={msg} />
    </div>
  );
}

// ChildA.tsx
import React from "react";

export default function ChildA({ onSend }: { onSend: (msg: string) => void }) {
  return <button onClick={() => onSend("来自 A 的消息")}>发送给B</button>;
}

// ChildB.tsx
import React from "react";

export default function ChildB({ message }: { message: string }) {
  return <p>B 收到: {message}</p>;
}

方式 2:使用 Context(跨层级共享数据)

适合较复杂的场景,避免"层层传 props"。

tsx 复制代码
import React, { createContext, useContext, useState } from "react";

const MsgContext = createContext<any>(null);

export default function Parent() {
  const [msg, setMsg] = useState("");

  return (
    <MsgContext.Provider value={{ msg, setMsg }}>
      <ChildA />
      <ChildB />
    </MsgContext.Provider>
  );
}

function ChildA() {
  const { setMsg } = useContext(MsgContext);
  return <button onClick={() => setMsg("ChildA 发来消息")}>发消息</button>;
}

function ChildB() {
  const { msg } = useContext(MsgContext);
  return <p>B 收到: {msg}</p>;
}

方式 3:状态管理库(Redux、Zustand、Recoil)

适合大型项目,状态多、组件复杂时使用。


✅ 总结:

  • 父子通信props
  • 子父通信:回调函数。
  • 同级通信:提升状态到父组件,或者用 Context/全局状态库。

相关推荐
陶甜也15 分钟前
3D智慧城市:blender建模、骨骼、动画、VUE、threeJs引入渲染,飞行视角,涟漪、人物行走
前端·3d·vue·blender·threejs·模型
患得患失94920 分钟前
【前端websocket】企业级功能清单
前端·websocket·网络协议
落魄江湖行20 分钟前
基础篇四 Nuxt4 全局样式与 CSS 模块
前端·css·typescript·nuxt4
禅思院21 分钟前
前端性能优化:从"术"到"道"的完整修炼指南
前端·架构·前端框架
叫我一声阿雷吧25 分钟前
JS 入门通关手册(43):async/await 原理与异常处理(实战 + 面试,彻底搞懂)
javascript·异常处理·promise·前端面试·async/await·generator·异步编程
架构师老Y1 小时前
003、Python Web框架深度对比:Django vs Flask vs FastAPI
前端·python·django
小陈工4 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
xiaotao1319 小时前
第九章:Vite API 参考手册
前端·vite·前端打包
午安~婉9 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
彧翎Pro9 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm