0

0

掌握 Redux 工具包:简化 React 应用程序中的状态管理

聖光之護

聖光之護

发布时间:2024-12-19 20:06:22

|

602人浏览过

|

来源于php中文网

原创

掌握 redux 工具包:简化 react 应用程序中的状态管理

Redux Toolkit:精简 React 状态管理

Redux Toolkit (RTK) 是 Redux 官方提供的工具库,旨在简化 Redux 在 React 应用中的配置和使用。Redux 功能强大,但其样板代码较多,RTK 通过提供一系列实用函数,有效降低了 Redux 开发的复杂度和门槛,提升开发效率。

RTK 帮助开发者更简洁、更结构化地配置 Store、编写 Reducer 和定义 Action。其内置的默认设置,能有效避免常见错误,减少冗余代码。


1. Redux Toolkit 简介

Redux Toolkit 是官方推荐的 Redux 库,它以更结构化、简洁且用户友好的方式处理 Redux 逻辑。通过提供一系列实用程序,RTK 消除了对重复代码的需求,例如自动处理不可变状态更新,简化 Action 创建和 Reducer 的编写。


2. Redux Toolkit 的核心特性

RTK 提供多种内置功能和实用程序,简化 Redux 的使用:

1. configureStore

configureStore 简化了 Store 的配置,自动添加必要的中间件(例如用于异步操作的 redux-thunk)并设置 Redux DevTools 进行调试。

示例:

import { configureStore } from '@reduxjs/toolkit';
import counterReducer from './counterSlice';

const store = configureStore({
  reducer: {
    counter: counterReducer,
  },
});

export default store;

configureStorecreateStore 更易用,更规范化。

2. createSlice

createSlice 简化了 Redux Slice 的创建。Slice 代表 Redux 状态的一部分,包含 Reducer 和 Action。

示例:

import { createSlice } from '@reduxjs/toolkit';

const counterSlice = createSlice({
  name: 'counter',
  initialState: { value: 0 },
  reducers: {
    increment: (state) => {
      state.value += 1; // immer.js 支持直接修改
    },
    decrement: (state) => {
      state.value -= 1;
    },
    incrementByAmount: (state, action) => {
      state.value += action.payload;
    },
  },
});

export const { increment, decrement, incrementByAmount } = counterSlice.actions;
export default counterSlice.reducer;

createSlice 自动生成 Action 创建函数和 Action 类型。

3. createAsyncThunk

createAsyncThunk 用于处理异步逻辑(例如 API 数据获取),并将其集成到 Redux 状态中。它生成一组 Action 创建函数(pending、fulfilled 和 rejected),用于管理异步流程。

示例:

import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';

export const fetchData = createAsyncThunk(
  'data/fetchData',
  async (url) => {
    const response = await fetch(url);
    return response.json();
  }
);

const dataSlice = createSlice({
  name: 'data',
  initialState: { items: [], status: 'idle' },
  reducers: {},
  extraReducers: (builder) => {
    builder
      .addCase(fetchData.pending, (state) => {
        state.status = 'loading';
      })
      .addCase(fetchData.fulfilled, (state, action) => {
        state.status = 'succeeded';
        state.items = action.payload;
      })
      .addCase(fetchData.rejected, (state) => {
        state.status = 'failed';
      });
  },
});

export default dataSlice.reducer;

createAsyncThunk 以清晰易懂的方式管理 Redux 中的异步请求。

4. createEntityAdapter

createEntityAdapter 用于管理 Redux 中的规范化数据,有效处理数据集合(例如项目列表)。

示例:

import { createEntityAdapter, createSlice } from '@reduxjs/toolkit';

const usersAdapter = createEntityAdapter();

const usersSlice = createSlice({
  name: 'users',
  initialState: usersAdapter.getInitialState(),
  reducers: {
    addUser: usersAdapter.addOne,
    removeUser: usersAdapter.removeOne,
  },
});

export const { addUser, removeUser } = usersSlice.actions;
export default usersSlice.reducer;

createEntityAdapter 简化了数据集合的处理,方便管理实体(添加、更新、删除)。


3. Redux Toolkit 的优势

android中音频视频开发教程 中文WORD版
android中音频视频开发教程 中文WORD版

媒体包提供了可管理各种媒体类型的类。这些类可提供用于执行音频和视频操作。除了基本操作之外,还可提供铃声管理、脸部识别以及音频路由控制。本文说明了音频和视频操作。 本文旨在针对希望简单了解Android编程的初学者而设计。本文将指导你逐步开发使用媒体(音频和视频)的应用程序。本文假定你已安装了可开发应用程序的Android和必要的工具,同时还假定你已熟悉Java或掌握面向对象的编程概念。感兴趣的朋友可以过来看看

下载

1. 减少样板代码

RTK 显著减少了 Redux 设置所需的样板代码。createSlice 自动生成所有必要的内容,无需手动编写 Action 类型、Action 创建函数和 Reducer。

2. 不可变更新 (通过 immer.js)

RTK 底层使用 immer.js,允许在 Reducer 中编写“可变”代码,但 immer 会自动创建状态副本并应用修改,确保状态保持不可变。

3. 提升开发者体验

自动配置 redux-thunk 等中间件,并与 Redux DevTools 集成,方便调试和监控 Redux 状态。RTK 也支持 TypeScript,增强类型安全。

4. 简化异步逻辑

createAsyncThunk 简化了异步逻辑的管理,无缝集成到 Redux 状态中。

5. 使用 createEntityAdapter 规范化数据

RTK 提供 createEntityAdapter 等实用程序,处理规范化数据,方便管理大量数据(例如用户列表)。


4. 在 React 应用中设置 Redux Toolkit

步骤 1:安装 Redux Toolkit 和 react-redux

npm install @reduxjs/toolkit react-redux

步骤 2:创建 Slice 和 Reducer

使用 createSlice 定义 Redux Slice。

// counterSlice.js
// ... (代码同 2.2 中 createSlice 示例)

步骤 3:配置 Store

使用 configureStore 配置 Redux Store。

// store.js
// ... (代码同 2.1 中 configureStore 示例)

步骤 4:在 React 组件中使用 Redux

使用 Provider 包装应用,使 Store 在整个应用中可用。

// App.js
import React from 'react';
import { Provider, useDispatch, useSelector } from 'react-redux';
import store from './store';
import { increment, decrement } from './counterSlice';

const Counter = () => {
  const count = useSelector((state) => state.counter.value);
  const dispatch = useDispatch();

  return (
    

Count: {count}

); }; const App = () => { return ( ); }; export default App;

useSelector 访问 Redux 状态,useDispatch 派发 Action 修改状态。


5. 总结

Redux Toolkit 通过减少样板代码,提供 createSlicecreateAsyncThunkconfigureStore 等实用函数,简化了 Redux 的使用。开发者可以专注于应用核心逻辑,无需处理 Redux 配置的复杂性。RTK 提供高效、易维护的方式管理同步和异步状态,是大型 React 应用的理想选择。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

178

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

214

2025.12.18

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

510

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5304

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

479

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

58

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
TypeScript 教程
TypeScript 教程

共19课时 | 2.4万人学习

TypeScript——十天技能课堂
TypeScript——十天技能课堂

共21课时 | 1.1万人学习

TypeScript-45分钟入门
TypeScript-45分钟入门

共6课时 | 0.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号