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

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

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

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]删除
最新教程 更多>
  • 释放 Claude AI:用于经济实惠且灵活的 AI 集成的非官方 API
    释放 Claude AI:用于经济实惠且灵活的 AI 集成的非官方 API
    由 Anthropic 开发的 Claude AI 以其令人印象深刻的能力在人工智能界掀起了波澜。然而,官方 API 对于许多开发人员和小型企业来说可能过于昂贵。这就是我们的非官方 Claude AI API 的用武之地,它提供了一个更实惠、更灵活的解决方案,将 Claude 的力量集成到您的项目中...
    编程 发布于2024-11-08
  • 如何使用时间包确定 Go 中一个月的最后一天?
    如何使用时间包确定 Go 中一个月的最后一天?
    使用 Time.Time 确定给定月份的最后一天处理基于时间的数据时,通常需要确定指定月份的最后一天。无论该月有 28 天、29 天(闰年)还是 30 天或 31 天,这都会使这成为一项具有挑战性的任务。时间包解决方案Go 时间包其日期函数提供了一个方便的解决方案。 Date 的语法为:func D...
    编程 发布于2024-11-08
  • 如何在不支持的浏览器中实现“背景滤镜”效果?
    如何在不支持的浏览器中实现“背景滤镜”效果?
    CSS:为不可用的背景过滤器提供替代方案CSS 中的背景过滤器功能在大多数现代浏览器中仍然无法访问。虽然我们预计其未来的支持,但发现替代解决方案势在必行。实现类似效果的一种方法是采用具有微妙透明度的背景。下面的 CSS 代码演示了这种方法:/* Slightly transparent fallba...
    编程 发布于2024-11-08
  • Python 的 len() 函数对于不同的数据结构有多高效?
    Python 的 len() 函数对于不同的数据结构有多高效?
    理解Python内置数据结构中len()函数的成本Python中内置len()函数是确定各种数据结构长度的重要工具。它的效率至关重要,尤其是在处理大型数据集时。本文深入研究了 len() 对于不同内置数据类型(例如列表、元组、字符串和字典)的计算成本。O(1) 跨内置类型的复杂性关键要点是 len(...
    编程 发布于2024-11-08
  • 如何在 Python 中访问 Windows 剪贴板文本?
    如何在 Python 中访问 Windows 剪贴板文本?
    在 Python 中访问 Windows 剪贴板文本从 Windows 剪贴板检索文本是编程中的常见任务。本文探讨了如何使用 Python 的 win32clipboard 模块来实现此目的。pywin32 和 win32clipboardwin32clipboard 模块是 pywin32 的一部...
    编程 发布于2024-11-08
  • 如何修复 CentOS 5 上由于文件权限问题导致的 Nginx 403 Forbidden 错误?
    如何修复 CentOS 5 上由于文件权限问题导致的 Nginx 403 Forbidden 错误?
    Nginx 403 Forbidden:文件访问权限故障排除当在 Nginx 中遇到令人沮丧的“403禁止”错误时,确定根本原因可以是一个挑战。此错误通常表示对文件或目录的访问被拒绝。在该特定场景中,用户在 CentOS 5 上使用 PHP-FPM 配置了 Nginx,但无法提供指定源目录中的任何文...
    编程 发布于2024-11-08
  • React 中的函数和类组件与 TypeScript
    React 中的函数和类组件与 TypeScript
    在使用 TypeScript 的 React 中,我们可以使用两种主要方法来创建组件:功能组件和类组件。两种方法都允许使用 props 和 state,但使用的范例略有不同。 TypeScript 通过提供静态类型进一步增强了开发安全性,这使我们能够精确定义 props 和 state 的形状。 ...
    编程 发布于2024-11-08
  • 如何使用 Clang 检查编译器生成的 C++ 模板实例化代码?
    如何使用 Clang 检查编译器生成的 C++ 模板实例化代码?
    检查 C 语言中编译器生成的模板实例化 在 C 语言中,模板函数和类允许通过定义通用功能来重用代码专门针对不同类型。要了解编译器为模板实例化生成的代码,了解这些实例化的函数或类会很有帮助。Clang 的 AST 打印功能一个工具提供这种可见性的是 Clang 的抽象语法树 (AST) 打印功能,Cl...
    编程 发布于2024-11-08
  • 我从使用 Vue.js 构建计算器中学到了什么
    我从使用 Vue.js 构建计算器中学到了什么
    对于我的第四个项目,我使用 Vue.js 开发了一个 计算器 应用程序。对于理解如何处理用户输入、显示动态结果以及使用 JavaScript 执行计算来说,这是一次宝贵的经验。以下是我在构建此应用程序时学到的主要经验教训的细分。 1. 处理用户输入并更新显示 计算器需要接受用户输入(...
    编程 发布于2024-11-08
  • 在 Kubernetes 上设置 JFrog Artifactory 并连接 Spring Boot 应用程序
    在 Kubernetes 上设置 JFrog Artifactory 并连接 Spring Boot 应用程序
    本文档提供有关在 Kubernetes 集群中设置 JFrog Artifactory 的指南。它作为开发人员在本地计算机上运行的 Kubernetes 环境上安装和配置 JFrog 的基本教程。 设置本地环境来构建DevOps资源 我使用 Docker 容器为多个应用程序设置工作环...
    编程 发布于2024-11-08
  • Angular 与 React:4 中你应该选择哪一个?
    Angular 与 React:4 中你应该选择哪一个?
    前端开发者总是面临一个大问题:Angular 还是 React? 两个框架都很强大,但哪一个真正适合你的开发需求? ? 在这个全面的比较中,我详细分析了每个项目的主要差异、优势和劣势,帮助您为下一个项目做出正确的选择。无论您是初学者还是经验丰富的专业人士,本文都会为您提供做出明智决定所需的见解。 ?...
    编程 发布于2024-11-08
  • 如何将 Props 传递给 React Router 中的处理程序组件?
    如何将 Props 传递给 React Router 中的处理程序组件?
    使用 React Router 将 Props 传递给处理程序组件在利用 React Router 的 React.js 应用程序中,您可能会遇到需要将 props 传递给特定处理程序组件的场景。考虑以下应用程序结构:var Dashboard = require('./Dashboard'); v...
    编程 发布于2024-11-08
  • 通过 Maroto 在 Golang 中生成 PDF 来进行长期操作
    通过 Maroto 在 Golang 中生成 PDF 来进行长期操作
    Written by Subha Chanda✏️ Go, also known as Golang, is a statically typed, compiled programming language designed by Google. It combines the performan...
    编程 发布于2024-11-08
  • 操作系统开发(真相)
    操作系统开发(真相)
    Table of Contents Introduction 1. The Bootloader: Kicking Things Off 2. Entering the Kernel: Where the Magic Happens 3. Choosing Your Languag...
    编程 发布于2024-11-08
  • 按值传递或引用传递:“想要速度?按值传递”何时是真的?
    按值传递或引用传递:“想要速度?按值传递”何时是真的?
    “想要速度?按价值传递” - 探索性能影响Scott Meyers 的声明“想要速度?按价值传递”提出了问题关于按值传递对象与按引用传递对象的性能优势。在这种情况下,按值传递涉及复制操作,而按引用传递则避免了不必要的复制。考虑以下结构体 X 和 Y 的示例:struct X { std::str...
    编程 发布于2024-11-08

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

Copyright© 2022 湘ICP备2022001581号-3