”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > Redux 工具包:React Thunk 和 React Saga。向 Vishal Tiwari 学习。

Redux 工具包:React Thunk 和 React Saga。向 Vishal Tiwari 学习。

发布于2024-11-09
浏览:534

Redux toolkit: React Thunk and React Saga.Learn from Vishal Tiwari.

React Thunk 和 React Saga 是用于处理 React 应用程序中副作用的中间件库,特别是用于管理 API 调用等异步操作。两者通常与 Redux 一起使用,但用途和方法略有不同。


React Thunk

1. 概述:

React Thunk 是一个中间件,允许您编写返回函数而不是操作对象的操作创建器。这对于处理异步操作(例如 API 请求)或复杂的同步逻辑(例如操作的条件分派)非常有用。返回的函数接收dispatch和getState作为参数,允许您调度其他操作或访问函数内的当前状态。

2. 关键概念:

  • 中间件: Thunk 是扩展商店处理函数(即 thunk)能力的中间件。
  • 异步操作:使用 Thunk,您可以延迟操作的分派或根据特定状态或逻辑有条件地分派它。
  • 简单: Thunk 相对简单,在大多数用例中都很容易使用。

3. 工作原理:

  • 通常,动作创建者返回纯 JavaScript 对象(动作)。
  • 使用 Thunk,动作创建者可以返回接收调度和 getState 的函数(“thunk”)。在此函数内,您可以执行异步逻辑(例如,从 API 获取数据),然后分派实际操作。

4. 示例:

以下是如何在 React 应用程序中使用 redux-thunk 的基本示例:

   // Action Creator with Thunk
   export const fetchUser = () => {
     return async (dispatch) => {
       dispatch({ type: 'FETCH_USER_REQUEST' });
       try {
         const response = await fetch('/api/user');
         const data = await response.json();
         dispatch({ type: 'FETCH_USER_SUCCESS', payload: data });
       } catch (error) {
         dispatch({ type: 'FETCH_USER_FAILURE', payload: error });
       }
     };
   };

5. Thunk的优点:

  • 简单性: Thunk 易于理解和实现。
  • 占地面积小:它重量轻,不需要复杂的配置。
  • 直接控制调度:您可以更好地控制何时以及如何调度操作。

6. 缺点:

  • 难以扩展:对于复杂的异步流程,Thunk 可能会变得混乱,具有嵌套逻辑和大量调度调用。
  • 更少的结构: Thunk 不强制使用特定的结构来管理副作用,如果处理不当,可能会导致代码不一致。

反应传奇

1. 概述:

React Saga是一个中间件,允许您使用生成器函数以更有组织的方式处理副作用。它不像 Thunk 那样返回函数,而是使用“效果”系统来管理异步操作并控制逻辑流程。 Sagas 是长时间运行的后台进程,可以侦听分派的操作并执行 API 调用、数据获取和其他任务等副作用。

2. 关键概念:

  • 生成器函数: Sagas 是使用 ES6 生成器函数 (function*) 实现的,它允许您编写看起来同步的异步代码。
  • 观察者和工作者:传奇通常分为“观察者”传奇(监听调度的动作)和“工作者”传奇(处理副作用)。
  • Take、put、call: Redux-Saga 提供了效果创建器(take、put、call 等)来控制何时触发副作用、调度操作和调用 API。

3. 工作原理:

  • 使用 Redux-Saga,您可以定义负责处理副作用的 sagas(长时间运行的后台任务)。
  • Sagas 通常被编写为生成器函数和产生效果,例如 call(调用函数)和 put(分派操作)。
  • Sagas 还可以使用 take 等待特定操作,或者使用 takeEvery 或 takeLatest 监听任何操作。

4. 示例:

这是如何使用 redux-saga 的基本示例:

   import { call, put, takeLatest } from 'redux-saga/effects';

   // Worker saga: will be fired on FETCH_USER_REQUEST actions
   function* fetchUser(action) {
     try {
       const response = yield call(fetch, '/api/user');
       const data = yield response.json();
       yield put({ type: 'FETCH_USER_SUCCESS', payload: data });
     } catch (e) {
       yield put({ type: 'FETCH_USER_FAILURE', message: e.message });
     }
   }

   // Watcher saga: spawns a new fetchUser task on each FETCH_USER_REQUEST
   function* mySaga() {
     yield takeLatest('FETCH_USER_REQUEST', fetchUser);
   }

   export default mySaga;

5. Redux-Saga的优点:

  • 更适合复杂的副作用: Saga 基于效果的方法更具可扩展性,适合管理复杂的异步流(例如,处理重试、去抖或级联 API 调用)。
  • 可测试: Sagas 很容易测试,因为它们是围绕生成器函数构建的。
  • 声明性:效果的使用可以让人们更清楚会发生什么副作用,使流程更加可预测。
  • 取消和顺序: Saga 可以轻松取消正在进行的任务或强制执行事件的顺序流(例如等待多个操作)。

6. 缺点:

  • 更陡峭的学习曲线:使用生成器函数和整体 saga 模式对于初学者来说可能很难掌握。
  • 开销:对于小型应用程序,与 Thunk 等更简单的解决方案相比,它可能感觉有点矫枉过正。
  • 详细:与 Thunk 相比,Sagas 往往涉及更多样板代码。

比较:React Thunk 与 React Saga

方面 React Thunk React Saga
概念 返回动作创建者中的函数 使用生成器函数产生副作用
学习曲线 更容易学习和使用 由于生成器而具有更高的学习曲线
异步流程 处理简单的异步逻辑 更适合复杂的异步工作流程
代码结构 结构较少,在大型应用程序中可能会变得混乱 提供清晰、结构化的方法
测试 测试可能更具挑战性 由于生成器而更容易测试
用例 简单的异步逻辑,API 请求 复杂流程(例如序列、重试)
表现 轻的 更强大,但开销稍大

何时使用哪个?

  • 使用 React Thunk if:

    • 您的应用程序有相对简单的异步需求,例如基本的API请求和基于条件的调度。
    • 您想要一个轻量级、易于理解、没有太多样板的解决方案。
  • 使用 React Saga 如果:

    • 您需要管理更复杂的异步流程,例如重试、操作排序、竞争条件或相互依赖的多个任务。
    • 您更喜欢声明式方法并希望更好地控制副作用。
    • 从长远来看,您的应用程序需要更好的可测试性和代码可维护性。
版本声明 本文转载于:https://dev.to/vishal_tiwari_114f21d14e5/redux-toolkit-react-thunk-and-react-sagalearn-from-vishal-tiwari-58b?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何将移动站点限制为横向并禁用自动旋转?
    如何将移动站点限制为横向并禁用自动旋转?
    增强移动网站体验:强制横向方向并禁用自动旋转在设计移动响应能力时,某些方向可能会对用户产生重大影响经验。此问题寻求一种解决方案,将移动网站限制为横向并禁用自动旋转。CSS 解决方案实现此目的的一种方法是通过 CSS 媒体查询。通过为横向和纵向创建单独的样式表,您可以根据设备的方向控制站点的行为方式。...
    编程 发布于2024-11-09
  • Mac OS X 上的 Python 项目创建
    Mac OS X 上的 Python 项目创建
    介绍 PyFabricate 是一款 Mac OS X 应用程序,可简化 Python 项目的创建。 自从我创作它以来,显然它是我认为 Python 项目应该是什么样子的一个固执己见的版本。 此外,我还有一个特定的工具集,可以用来编写 Python Mac OS X 应用程序。...
    编程 发布于2024-11-09
  • 如何修复 PHP 中的“尝试获取非对象的属性”错误?
    如何修复 PHP 中的“尝试获取非对象的属性”错误?
    解决 PHP 中的“尝试获取非对象的属性”错误使用 PHP 时,您可能会遇到错误“尝试获取非对象的属性”获得非物体的财产。”当尝试访问尚未正确初始化或为 null 的对象的属性时,通常会发生此错误。在提供的代码的情况下,问题在于从数据库获取侧菜单数据。 mysql_fetch_object() 函数...
    编程 发布于2024-11-09
  • 如何防止 Pandas 在保存 CSV 时添加索引列?
    如何防止 Pandas 在保存 CSV 时添加索引列?
    避免使用 Pandas 保存的 CSV 中的索引列使用 Pandas 进行修改后保存 csv 文件时,默认行为是包含索引列。为了避免这种情况,可以在使用 to_csv() 方法时将索引参数设置为 False。为了详细说明,请考虑以下命令序列:pd.read_csv('C:/Path/to/file....
    编程 发布于2024-11-09
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为 bool 的主要场景:语句:if、w...
    编程 发布于2024-11-09
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-09
  • ## 如何修改 Python 源代码,同时保留格式和注释?
    ## 如何修改 Python 源代码,同时保留格式和注释?
    使用 AST 修改 Python 源代码解析、修改和写回 Python 源代码对于突变测试等任务来说是一项很有价值的任务。虽然标准 Python 模块提供了解析和编译代码的方法,但它们缺乏修改和重写源代码的能力。为了满足这一需求,一些库提供了解决方案:lib2to3: 由 Pythscope 和 2...
    编程 发布于2024-11-09
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-09
  • 如何使用 JavaScript 根据另一个下拉列表中的选择填充一个下拉列表?
    如何使用 JavaScript 根据另一个下拉列表中的选择填充一个下拉列表?
    使用 JavaScript 根据另一个下拉列表中的选择填充一个下拉列表当面临根据另一个下拉列表中的选择动态更新一个下拉列表中的选项的任务时,它是对于避免不必要的复杂性(例如数据库查询)至关重要。让我们探索一个简单的基于 JavaScript 的解决方案,无需 AJAX 调用即可完成此任务。为了说明此...
    编程 发布于2024-11-09
  • 如何从具有不同数组长度的字典创建 Pandas DataFrame?
    如何从具有不同数组长度的字典创建 Pandas DataFrame?
    从条目长度不均匀的字典创建 DataFrame在 Python 中,可以从每个条目保存一个 Numpy 数组的字典创建 DataFrame。然而,当条目之间的数组长度不同时,就会出现挑战。默认情况下,Pandas 需要统一长度的数组,从而导致类似“ValueError: arrays must al...
    编程 发布于2024-11-09
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-09
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-09
  • 为什么在 Java 中使用相同的种子时会得到相同的随机数?
    为什么在 Java 中使用相同的种子时会得到相同的随机数?
    具有固定种子的Java随机数:为什么输出相同?在您的代码中,您定义了一种使用以下命令生成随机数的方法指定的种子。但是,您会注意到,当您提供相同的种子时,所有 100 个生成的数字都是相同的。此行为是预期的,因为在 Random 构造函数中使用相同的种子会产生可预测的数字序列。种子是初始化随机数生成器...
    编程 发布于2024-11-09
  • jQuery Chaining 如何简化开发并提高代码效率?
    jQuery Chaining 如何简化开发并提高代码效率?
    理解 jQuery 中的对象和方法链接在 jQuery 中,链接允许在单个语句中串联多个 jQuery 方法。这使开发人员能够简化代码并轻松执行复杂的操作。链接的基本原理涉及每个 jQuery 方法的返回值。当调用 jQuery 方法时,它通常返回一个表示所选元素的 jQuery 对象。这允许在同一...
    编程 发布于2024-11-09
  • Hono.js 基准测试:Node.js、Deno 和 Bun — 哪个最快?
    Hono.js 基准测试:Node.js、Deno 和 Bun — 哪个最快?
    Deno 2.0 刚刚发布,并声称比 Bun 和 Node.js 更快,同样,Bun 也声称更快。这引起了我的兴趣,所以我决定测试它们的性能,看看它们在现实场景中的比较。 为了公平比较,我需要选择一个与所有三种 JavaScript 运行时环境(Node.js、Deno 和 Bun)兼容的框架。这就...
    编程 发布于2024-11-09

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

Copyright© 2022 湘ICP备2022001581号-3