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

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

redux 工具包的用途

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

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

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

redux 工具包的主要优点:

更少的样板代码:不再需要动作创建者和常量。简化的商店设置:提供单个 api 来使用合理的默认值配置商店。内置对不变性和 devtools 的支持:自动启用 redux devtools 并与 immer 集成以实现不变性。更好的 typescript 支持:提供更好的打字效果并与 typescript 很好地集成。

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

在 react 应用程序中设置 redux 工具包

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

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

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

第 2 步:安装 redux 工具包和 react-redux

LuckyCola工具库 LuckyCola工具库

LuckyCola工具库是您工作学习的智能助手,提供一系列AI驱动的工具,旨在为您的生活带来便利与高效。

LuckyCola工具库 19 查看详情 LuckyCola工具库

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

npm install @reduxjs/toolkit react-redux

了解切片和减速器

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

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

// src/features/counter/counterslice.jsimport { 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 函数生成动作创建者。

配置 redux 存储

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

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

// src/app/store.jsimport { 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.jsimport 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'));

将组件连接到商店

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

// src/features/counter/counter.jsimport 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.jsimport React from 'react';import Counter from './features/counter/Counter';function App() {  return (    
);}export default App;

结论和后续步骤

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

敬请关注第 2 部分:高级 redux 工具包 – 使用 createasyncthunk 的异步逻辑!

以上就是完整的 Redux 工具包(第 1 部分)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/454630.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 00:53:56
下一篇 2025年11月8日 00:54:24

相关推荐

  • 如何使用CSS的object-position实现图片在img标签中的定位

    直接答案:利用 CSS 的 object-position 属性,输入两个值分别表示图像水平和垂直方向上的定位。水平定位值:left(左),right(右),center(中心),百分比(%),start(开始),end(结束)。垂直定位值:top(上),bottom(下),center(中心),百…

    2025年12月18日
    000
  • CSS Grid 布局在 IE 中不兼容的原因及解决方案

    IE 不兼容 CSS Grid 布局的原因是它不支持 CSS Grid 规范。解决方案包括:1. 使用 polyfills 模拟现代浏览器功能;2. 切换到支持 CSS Grid 布局的浏览器;3. 使用替代布局技术(如 Flexbox)。 CSS Grid 布局在 IE 中不兼容的原因 CSS G…

    2025年12月18日
    000
  • HTML5使用details标签:展开/收缩信息

    HTML5 的 details 标签用于展示可折叠信息,让用户按需查看详情。语法为:,包含 (可点击标题)和要显示/隐藏的内容。可以通过 open 属性在页面加载时控制内容的初始显示状态。details 标签可使用 CSS 进行样式化。 HTML5 中的 details 标签:显示和隐藏信息 HTM…

    2025年12月18日
    000
  • 15 个为编程初学者准备的网站(都是国外的一些网站)

    对于编程初学者,以下 15 个网站提供了基础课程、教程和互动练习:1. Codecademy提供交互式学习、2. Free Code Camp提供免费的全栈开发课程、3. W3Schools提供涵盖 Web 开发技术的综合参考、4. Khan Academy提供计算机科学课程、5. Udemy提供付…

    2025年12月18日
    000
  • CSS给div一个带有圆角的渐变边框效果

    使用 CSS 的 border-radius 和 background-image 属性,可以为 div 添加带有圆角的渐变边框:创建一个从蓝色到红色的线性渐变背景。设置 div 的边框圆角半径。 如何使用 CSS 为 div 添加带有圆角的渐变边框? 方法: 使用 CSS 的 border-rad…

    2025年12月18日
    000
  • CSS 布局技巧实现元素左右排列的方法

    CSS 布局中,元素水平排列技巧包括:将元素设置为行内元素(display: inline 或 inline-block)使用浮动(float: left 或 float: right)设置弹性盒子(justify-content: flex-start 或 flex-end)使用网格布局(grid…

    2025年12月18日
    000
  • CSS中隐藏滚动条的同时保留滚动功能

    如何在 CSS 中隐藏滚动条的同时保留滚动功能?使用 overflow: hidden; 隐藏滚动条,但会禁用滚动。使用 overflow: scroll; 和 CSS 自定义样式隐藏滚动条,但保留滚动功能。使用 CSS 自定义滚动条,提供更灵活的外观控制。使用 JavaScript 动态隐藏滚动条…

    2025年12月18日
    000
  • CSS实现回到顶部且平滑过渡

    在 CSS 中实现一个带有平滑过渡效果的回到顶部按钮,需要以下步骤:添加带有 id=”back-to-top” 的 元素;将按钮设置为固定定位,添加样式(包括初始透明度为 0);在按钮悬停时将透明度设置为 1,并添加平滑过渡效果;使用 JavaScript 为按钮添加滚动检测…

    2025年12月18日
    000
  • 使用CSS3和SVG创建圆形进度条动画效果

    可以使用 CSS3 和 SVG 创建圆形进度条动画效果,步骤如下:创建 SVG 元素并定义圆形路径;为圆形路径设置虚线样式;使用 CSS3 动画控制虚线的偏移量;通过调整虚线的初始偏移量设置进度百分比。 使用 CSS3 和 SVG 创建圆形进度条动画效果 圆形进度条动画效果是一种简洁而有效的方法,可…

    2025年12月18日
    000
  • CSS border 边框的全面指南

    CSS 边框是一种在元素周围添加视觉分隔的有效方法。您可以通过设置 border-width、border-style、border-color 属性来创建边框。CSS 边框由四个部分组成:上边框、右边框、下边框、左边框。您可以使用 border-radius 属性添加圆角。box-shadow 属…

    2025年12月18日
    000
  • 【Rust自学】简介

    1.0.1 前言 这个项目(包括代码和注释)是在我自学 Rust 的过程中记录的。可能有不准确或表述不清的地方,还请大家谅解。如果您从中受益,那就更好了。 1.0.2 为什么使用 Rust Rust 可靠且高效。 Rust 可以取代 C 和 C ,性能相似但安全性更高,并且不需要像 C 和 C 那样…

    2025年12月18日
    000
  • 使用HTML和CSS实现文字镂空效果的代码示例

    使用 HTML 和 CSS 实现文字镂空效果,需要以下步骤:通过 background-image 属性给 HTML 元素设置背景图像。使用 clip-path 属性定义镂空区域的形状,包括矩形、圆形、椭圆和多边形。通过 SHAPE-DEFINITION 来描述镂空区域的具体形状,例如使用 circ…

    2025年12月18日
    000
  • Streamlit应用程序

    C 客户流失是当今许多企业面临的紧迫问题,尤其是在竞争激烈的软件即服务 (SaaS) 市场中。随着越来越多的服务提供商进入市场,客户拥有了丰富的选择。这给企业留住客户带来了重大挑战。本质上,流失是指客户停止使用服务或购买产品时的流失。虽然客户流失可能因行业而异,但有一些共同因素会导致客户流失,例如:…

    2025年12月18日
    000
  • 如何将 C++ 框架与 Web 开发技术集成?

    将 c++++ 框架与 web 开发技术集成是一种创建高性能、可扩展 web 应用程序的方法。通过选择一个如 boost.asio 的 c++ 框架,并将其与restful api框架(如 restbed)和 web 服务器(如 apache)结合,您可以构建全栈应用程序。实战案例展示了使用 boo…

    2025年12月18日
    000
  • 如何将C++框架与图形处理集成

    将 c++++ 框架与图形处理集成在现代软件开发中十分普遍,能结合二者的优势打造高效、可扩展的应用程序。可通过以下方式集成:使用 qt 框架,它提供 gui 开发和图形处理功能;集成 opencv 库,提供数百种图像处理和计算机视觉算法;实战案例:创建一个简单的图像编辑器,使用 qgraphicsv…

    2025年12月18日
    000
  • 如何将C++框架与CSS技术集成

    在 c++++ 框架中集成 css 允许开发人员使用熟悉的 css 规则美化应用程序界面。步骤包括:安装 css 库(如 libcsspp、csspp、smile);添加一个 css 文件并定义样式规则;使用库函数将 css 文件应用到框架中。 在 C++ 框架中集成 CSS 技术 CSS(层叠样式…

    2025年12月18日
    000
  • 如何使用代码分析工具优化C++框架的性能?

    使用代码分析工具优化 c++++ 框架性能的步骤:选择一个代码分析工具,例如 valgrind 或 clang static analyzer。将工具集成到构建过程中,以在每次构建时自动运行分析。运行分析并查看报告,优先考虑最关键的问题。根据报告中的建议解决问题,例如修复内存泄漏或添加检查。重新运行…

    2025年12月18日
    000
  • 如何选择最佳C++框架来实现高性能应用?

    最佳 c++++ 框架选择应重点考虑性能:内存管理、并发处理、代码生成和基准测试。领先框架包括 boost、qt、cinder、armadillo 和 eigen。实战案例展示了使用 qt 构建高性能图像处理应用,显著提升了速度和实时交互性,证明了 c++ 框架在高性能应用开发中的有效性。 如何选择…

    2025年12月18日
    000
  • C++框架选择指南:初学者的最佳选择

    c++++框架选择指南:初学者最佳框架:qt:易学、全面,适合gui设计。boost:实用工具库,简化开发。选择标准:学习曲线文档社区支持适用性 C++框架选择指南:初学者最佳之选 对于初学者来说,选择合适的C++框架对于构建稳固且可扩展的应用程序至关重要。本指南将提供一个全面的框架选择指南,重点关…

    2025年12月18日
    000
  • C++框架在教育领域的应用

    c++++ 框架在教育领域具有广泛应用,通过提供预建组件和一致的约定,简化应用程序开发并提高代码质量。主要优势包括代码可重用性、可维护性、测试支持和性能优化。常用 c++ 框架包括 qt、boost.asio、eigen 和 opencv,可用于构建互动式学习工具、数据可视化应用程序和教育管理系统。…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信