当前位置: 首页 > news >正文

【大前端】React 使用 Redux 实现组件通信的 Demo 示例

React 使用 Redux 实现组件通信的 Demo 示例

在 React 项目中,父子组件通信通常依赖 props,兄弟组件通信则通过 状态提升Context。但是当应用逐渐复杂时,这种方式会显得繁琐。此时 Redux 就派上用场了 —— 它可以集中管理全局状态,任何组件都能方便地订阅和修改状态。

本文将带你实现一个简单的 计数器 demo,演示 Redux 在 React 中的组件通信。


一、环境准备

安装必要依赖:

npm install @reduxjs/toolkit react-redux

Redux Toolkit(RTK)是 Redux 官方推荐的写法,简化了很多冗余代码。


二、目录结构

src/store.tsfeatures/counter/counterSlice.tsCounterA.tsxCounterB.tsxApp.tsxindex.tsxhooks.ts

这里我们会写两个兄弟组件:CounterACounterB,通过 Redux 实现通信。


三、配置 Redux Store

src/store.ts

import { configureStore } from "@reduxjs/toolkit";
import counterReducer from "./features/counter/counterSlice";export const store = configureStore({reducer: {counter: counterReducer,},
});export type RootState = ReturnType<typeof store.getState>;
export type AppDispatch = typeof store.dispatch;

四、定义 Slice(状态逻辑)

src/features/counter/counterSlice.ts

import { createSlice, PayloadAction } from "@reduxjs/toolkit";
import { RootState } from "../../store";interface CounterState {value: number;
}const initialState: CounterState = { value: 0 };const counterSlice = createSlice({name: "counter",initialState,reducers: {increment: (state) => {state.value += 1;},decrement: (state) => {state.value -= 1;},addBy: (state, action: PayloadAction<number>) => {state.value += action.payload;},},
});export const { increment, decrement, addBy } = counterSlice.actions;
export default counterSlice.reducer;// 选择器
export const selectCount = (state: RootState) => state.counter.value;

五、封装 Typed Hooks(TS推荐)

src/hooks.ts

import { TypedUseSelectorHook, useDispatch, useSelector } from "react-redux";
import type { RootState, AppDispatch } from "./store";export const useAppDispatch = () => useDispatch<AppDispatch>();
export const useAppSelector: TypedUseSelectorHook<RootState> = useSelector;

六、兄弟组件通信示例

CounterA.tsx

import React from "react";
import { useAppDispatch } from "../../hooks";
import { increment, addBy } from "./counterSlice";export default function CounterA() {const dispatch = useAppDispatch();return (<div style={{ border: "1px solid #ccc", padding: 10, margin: 10 }}><h3>我是 CounterA</h3><button onClick={() => dispatch(increment())}>+1</button><button onClick={() => dispatch(addBy(5))}>+5</button></div>);
}

CounterB.tsx

import React from "react";
import { useAppSelector } from "../../hooks";
import { selectCount } from "./counterSlice";export default function CounterB() {const count = useAppSelector(selectCount);return (<div style={{ border: "1px solid #ccc", padding: 10, margin: 10 }}><h3>我是 CounterB</h3><p>当前计数:{count}</p></div>);
}

七、应用入口

App.tsx

import React from "react";
import CounterA from "./features/counter/CounterA";
import CounterB from "./features/counter/CounterB";export default function App() {return (<div style={{ padding: 20 }}><h2>Redux 通信 Demo</h2><CounterA /><CounterB /></div>);
}

index.tsx

import React from "react";
import { createRoot } from "react-dom/client";
import { Provider } from "react-redux";
import { store } from "./store";
import App from "./App";const root = createRoot(document.getElementById("root")!);
root.render(<Provider store={store}><App /></Provider>
);

八、运行效果

  1. 点击 CounterA 中的 +1+5 按钮,会触发 Redux 的 dispatch,修改全局状态。
  2. CounterB 会实时响应,展示最新的计数值。

👉 这就实现了 兄弟组件通信,而且随着应用规模扩大,你只需要在需要的地方使用 Redux,不再需要复杂的 props 传递。


九、总结

  • 父子通信:直接用 props。
  • 兄弟通信:Redux 是一种集中化管理方式,适合跨层级或复杂场景。
  • Redux Toolkit 简化了 reducer 和 action 的写法,官方推荐。
  • 在更大规模应用中,还可以结合 Redux Persist(持久化存储)、RTK Query(数据请求管理)。

http://www.dtcms.com/a/364379.html

相关文章:

  • React实现点击按钮复制操作【navigator.clipboard与document.execCommand】
  • 基于单片机PWM信号发生器系统Proteus仿真(含全部资料)
  • 平衡车 - 电机调速
  • 基于单片机车内换气温度检测空气质量检测系统Proteus仿真(含全部资料)
  • 单片机点灯
  • Linux 网络编程中核心函数`recv`。
  • zynq 开发系列 新手入门:GPIO 连接 MIO 控制 LED 闪烁(SDK 端代码编写详解)
  • Spring Boot 实现数据库表变更监听的 Redis 消息队列方案
  • 单片机控制两只直流电机正反转C语言
  • 变频器实习DAY42 VF与IF电机启动方式
  • Excel 电影名匹配图片路径教程:自动查找并写入系统全路径
  • wpf 自定义控件,只能输入小数点,并且能控制小数点位数
  • 机器学习从入门到精通 - Python环境搭建与Jupyter魔法:机器学习起航必备
  • 如何在modelscope上上传自己的MCP服务
  • 【收藏】2025 前端开发者必备 SVG 资源大全
  • 【2025ICCV-持续学习方向】一种用于提示持续学习(Prompt-based Continual Learning, PCL)的新方法
  • 【CouponHub开发记录】SpringAop和分布式锁进行自定义注解实现防止重复提交
  • RAG|| LangChain || LlamaIndex || RAGflow
  • kafka概念之间关系梳理
  • mac idea 配置了Gitlab的远程地址,但是每次pull 或者push 都要输入密码,怎么办
  • 项目中常用的git命令
  • python基础案例-数据可视化
  • Streamlit 数据看板模板:非前端选手快速搭建 Python 数据可视化交互看板的实用工具
  • 【Linux】为什么死循环卡不死 Linux?3 个核心逻辑看懂进程优先级与 CPU 调度密码
  • Langchain4j 整合MongoDB 实现会话持久化存储详解
  • 电表连网不用跑现场!耐达讯自动化RS485转Profinet网关 远程配置+技术支持,真能做到!
  • 单元测试数据库回滚问题
  • 如何在FastAPI中巧妙隔离依赖项,让单元测试不再头疼?
  • 10 分钟掌握 Selenium 8 大元素定位法:从踩坑到精通
  • Python分布式任务队列:万级节点集群的弹性调度实践