”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 完整的 Redux 工具包(第 1 部分)

完整的 Redux 工具包(第 1 部分)

发布于2024-10-31
浏览:797

Complete Redux toolkit (Part-1)

Redux工具包的用途

我们已经知道 redux 是 JavaScript 应用程序的一个强大的状态管理库,特别是在使用 React 时。
但是使用 redux 很困难,因为它设置 redux 的代码很繁重。这使得维护和调试变得困难。这就是 Redux Toolkit 可以提供帮助的地方。
Redux工具包问题解决

  • 开店太复杂了。
  • 添加许多包以与 redux 一起使用,例如中间件、工具。
  • Redux 需要太多代码来设置

Redux工具包是官方推荐的编写redux逻辑的方法。它提供了一组工具来简化开发,减少样板代码,有助于使应用程序具有可扩展性和可维护性。

Redux 工具包的主要优点:

  1. 更少的样板代码:不再需要动作创建者和常量。
  2. 简化商店设置:提供单个 API 来使用合理的默认值配置商店。
  3. 对不变性和 DevTools 的内置支持:自动启用 Redux DevTools 并与 Immer 集成以实现不变性。
  4. 更好的 TypeScript 支持:提供更好的打字并与 TypeScript 很好地集成。

我们可以将 redux 工具包与任何 javascript 库一起使用,因此我们使用 React 设置 redux 工具包。

在 React 应用程序中设置 Redux Toolkit

第 1 步:创建一个新的 React 项目

首先,让我们创建一个新的 React 应用程序。您可以使用 create-react-app 或 Vite 来实现此目的。为了简单起见,我们将在这里使用 create-react-app。

npx create-react-app redux-toolkit-example
cd redux-toolkit-example

第2步:安装Redux工具包和React-Redux

接下来,安装必要的软件包:@reduxjs/toolkit和react-redux。

npm install @reduxjs/toolkit react-redux
  1. 了解切片和减速器

切片是针对应用程序特定功能的 Redux 减速器逻辑和操作的集合。 Redux Toolkit 提供了 createSlice 函数来帮助使用最少的样板创建状态切片。

第 1 步:创建切片
让我们创建一个简单的计数器切片。在 features/counter 目录中创建一个名为 counterSlice.js 的新文件:

// src/features/counter/counterSlice.js
import { createSlice } from '@reduxjs/toolkit';

const initialState = {
  value: 0,
};

const counterSlice = createSlice({
  name: 'counter',
  initialState,
  reducers: {
    increment: (state) => {
      state.value  = 1;
    },
    decrement: (state) => {
      state.value -= 1;
    },
    incrementByAmount: (state, action) => {
      state.value  = action.payload;
    },
  },
});

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

在这里,我们定义了一个名为 counter 的切片,它具有初始状态和三个减速器(increment、decrement 和incrementByAmount)。 createSlice 函数自动为每个reducer 函数生成动作创建者。

  1. 配置 Redux Store

现在我们有了切片,让我们配置 Redux 存储。 Redux Toolkit 提供了一个 configureStore 函数,可以使用良好的默认值设置存储。

第 1 步:创建商店
在应用程序目录中创建 store.js 文件:

// src/app/store.js
import { configureStore } from '@reduxjs/toolkit';
import counterReducer from '../features/counter/counterSlice';

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

export default store;

第 2 步:为您的应用程序提供商店
将您的 React 应用程序包装在react-redux 的组件中并将其传递给商店。更新index.js文件:

// src/index.js
import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import { Provider } from 'react-redux';
import store from './app/store';

ReactDOM.render(
  
    
      
    
  ,
  document.getElementById('root')
);
  1. 将组件连接到 Store

要与 Redux 存储交互,请使用react-redux 提供的 useSelector 和 useDispatch 钩子。
第 1 步:使用 useSelector
访问状态 使用 useSelector 钩子从 store 访问状态

// src/features/counter/Counter.js
import React from 'react';
import { useSelector, useDispatch } from 'react-redux';
import { increment, decrement, incrementByAmount } from './counterSlice';

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

  return (
    

{count}

); }; export default Counter;

第 2 步:在应用程序中使用计数器组件
在您的主应用程序组件中导入并使用 Counter 组件:

// src/App.js
import React from 'react';
import Counter from './features/counter/Counter';

function App() {
  return (
    
); } export default App;
  1. 结论和后续步骤

在这一部分中,我们介绍了在 React 应用程序中设置 Redux Toolkit 的基础知识,包括创建切片、配置存储以及使用钩子将组件连接到 Redux 存储。在下一部分中,我们将深入研究使用 createAsyncThunk 处理异步逻辑,以从 API 获取数据并管理不同的加载状态。

敬请关注第 2 部分:高级 Redux 工具包 - 使用 createAsyncThunk 的异步逻辑!

版本声明 本文转载于:https://dev.to/abhishekpanwarrr/complete-redux-toolkit-part-1-58ph?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 您如何在Laravel Blade模板中定义变量?
    您如何在Laravel Blade模板中定义变量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配变量对于存储以后使用的数据至关重要。在使用“ {{}}”分配变量的同时,它可能并不总是最优雅的解决方案。幸运的是,Blade通过@php Directive提供了更优雅的方法: $ old_section =“...
    编程 发布于2025-03-28
  • 如何使用PHP将斑点(图像)正确插入MySQL?
    如何使用PHP将斑点(图像)正确插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call ...
    编程 发布于2025-03-28
  • 如何在Java字符串中有效替换多个子字符串?
    如何在Java字符串中有效替换多个子字符串?
    在java 中有效地替换多个substring,需要在需要替换一个字符串中的多个substring的情况下,很容易求助于重复应用字符串的刺激力量。 However, this can be inefficient for large strings or when working with nu...
    编程 发布于2025-03-28
  • 您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    在javascript console 中显示颜色是可以使用chrome的控制台显示彩色文本,例如红色的redors,for for for for错误消息?回答是的,可以使用CSS将颜色添加到Chrome和Firefox中的控制台显示的消息(版本31或更高版本)中。要实现这一目标,请使用以下模...
    编程 发布于2025-03-28
  • 如何使用Python的请求和假用户代理绕过网站块?
    如何使用Python的请求和假用户代理绕过网站块?
    如何使用Python的请求模拟浏览器行为,以及伪造的用户代理提供了一个用户 - 代理标头一个有效方法是提供有效的用户式header,以提供有效的用户 - 设置,该标题可以通过browser和Acterner Systems the equestersystermery和操作系统。通过模仿像Chro...
    编程 发布于2025-03-28
  • 如何从PHP中的数组中提取随机元素?
    如何从PHP中的数组中提取随机元素?
    从阵列中的随机选择,可以轻松从数组中获取随机项目。考虑以下数组:; 从此数组中检索一个随机项目,利用array_rand( array_rand()函数从数组返回一个随机键。通过将$项目数组索引使用此键,我们可以从数组中访问一个随机元素。这种方法为选择随机项目提供了一种直接且可靠的方法。
    编程 发布于2025-03-28
  • 为什么PHP的DateTime :: Modify('+1个月')会产生意外的结果?
    为什么PHP的DateTime :: Modify('+1个月')会产生意外的结果?
    使用php dateTime修改月份:发现预期的行为在使用PHP的DateTime类时,添加或减去几个月可能并不总是会产生预期的结果。正如文档所警告的那样,“当心”这些操作的“不像看起来那样直观。 考虑文档中给出的示例:这是内部发生的事情: 现在在3月3日添加另一个月,因为2月在2001年只有2...
    编程 发布于2025-03-28
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    在使用GO MOD时,在GO MOD 中克服模块路径差异时,可能会遇到冲突,其中3个Party Package将另一个PAXPANCE带有导入式套件之间的另一个软件包,并在导入式套件之间导入另一个软件包。如回声消息所证明的那样: go.etcd.io/bbolt [&&&&&&&&&&&&&&&&...
    编程 发布于2025-03-28
  • 为什么在我的Linux服务器上安装Archive_Zip后,我找不到“ class \” class \'ziparchive \'错误?
    为什么在我的Linux服务器上安装Archive_Zip后,我找不到“ class \” class \'ziparchive \'错误?
    Class 'ZipArchive' Not Found Error While Installing Archive_Zip on Linux ServerSymptom:When attempting to run a script that utilizes the ZipAr...
    编程 发布于2025-03-28
  • \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    答案: 在大多数现代编译器中,while(1)和(1)和(;;)之间没有性能差异。编译器: perl: 1 输入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    编程 发布于2025-03-28
  • Java是否允许多种返回类型:仔细研究通用方法?
    Java是否允许多种返回类型:仔细研究通用方法?
    在Java中的多个返回类型:一种误解类型:在Java编程中揭示,在Java编程中,Peculiar方法签名可能会出现,可能会出现,使开发人员陷入困境,使开发人员陷入困境。 getResult(string s); ,其中foo是自定义类。该方法声明似乎拥有两种返回类型:列表和E。但这确实是如此吗...
    编程 发布于2025-03-28
  • 如何在无序集合中为元组实现通用哈希功能?
    如何在无序集合中为元组实现通用哈希功能?
    在未订购的集合中的元素要纠正此问题,一种方法是手动为特定元组类型定义哈希函数,例如: template template template 。 struct std :: hash { size_t operator()(std :: tuple const&tuple)const {...
    编程 发布于2025-03-28
  • PHP阵列键值异常:了解07和08的好奇情况
    PHP阵列键值异常:了解07和08的好奇情况
    PHP数组键值问题,使用07&08 在给定数月的数组中,键值07和08呈现令人困惑的行为时,就会出现一个不寻常的问题。运行print_r($月)返回意外结果:键“ 07”丢失,而键“ 08”分配给了9月的值。此问题源于PHP对领先零的解释。当一个数字带有0(例如07或08)的前缀时,PHP将其...
    编程 发布于2025-03-28
  • 为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    The Mystery of "Broken" Two-Phase Template Instantiation in Microsoft Visual C Problem Statement:Users commonly express concerns that Micro...
    编程 发布于2025-03-28
  • 如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    在Visual Studio 2012 尽管已安装了MySQL Connector v.6.5.4,但无法将MySQL数据库添加到实体框架的“ DataSource对话框”中。为了解决这一问题,至关重要的是要了解MySQL连接器v.6.5.5及以后的6.6.x版本将提供MySQL的官方Visual...
    编程 发布于2025-03-28

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3