当前位置: 首页 > 知识库问答 >
问题:

Redux Thunk和Redux Saga有什么区别?

陆琦
2023-03-14

Redux Thunk和Redux Saga都是Redux的中间件。两者之间的区别是什么?如何确定何时使用Redux Thunk或Redux Saga?

共有2个答案

左丘曦
2023-03-14

其实两者都是< code>Redux处理异步动作的中间件。为了了解两者之间的区别,请注意下面的图片:

中间件框通常是指将现有软件中的单独功能粘合在一起的软件服务。对于Redux,中间件提供了一个第三方扩展点,用于发送操作和将操作交给reducer。然后减速器产生新的状态。

Redux-Thunk是一个中间件,允许您调用返回函数而不是操作对象的操作创建者。该函数接收存储的分派方法,一旦异步操作完成,该方法将用于分派函数体内的常规同步操作。352B容量,简单易学,易于使用

Redux Saga利用了一个名为GeneratorsES6功能,允许我们编写看起来同步且非常易于测试的异步代码。在saga中,我们可以轻松测试我们的异步流,我们的操作保持纯粹。复杂,难以学习和理解,14kB体积,但很容易组织复杂的异步操作,使其非常易读,saga有许多有用的工具来处理异步操作

提示:如果您无法理解它们之间的区别或理解redux传奇流程,但仍希望有可读的代码并避免回调地狱,请使用async/awaitredux-thunk

// simple usage of redux-thunk:
export const asyncApiCall = values => {
  return dispatch => {
    return axios.get(url)
      .then(response =>{
        dispatch(successHandle(response));
      })
      .catch(error => {
        dispatch(errorHandle(error));
      });
    };
  };



// async/await usage of redux-thunk:
export const asyncApiCall = values => {
  return async dispatch => {
    try {
      const response = await axios.get(url);
      dispatch(successHandle(response));
    }
    catch(error) {
      dispatch(errorHandle(error));
    }
  };
};
洪光霁
2023-03-14

Redux Thunk和Redux Saga都会处理副作用。简单地说,应用于最常见的场景(异步函数,特别是AJAX调用),Thunk允许Promises处理它们,Saga使用Generator。Thunk简单易用,Promises对许多开发人员都很熟悉,Saga/Generators更强大,但您需要学习它们。当Promises足够好时,Thunk也足够好,当您定期处理更复杂的案例时,Saga会为您提供更好的工具。

例如,当您在路由/视图中启动AJAX调用,然后用户移动到另一个视图时会发生什么?无论如何,您能安全地让减速器更改状态吗?Saga使取消效果变得微不足道,Thunk要求您处理它,解决方案不能很好地扩展。

实际上,选择其中一个确实取决于(同义反复)项目。

需要记住的一点是,这两个中间件可以共存,所以您可以从Thunks开始,在需要的时候引入Sagas(然后根据实际经验选择如何重构/重构什么...特别适合“学习项目”、MVP等的解决方案)一般来说,Sagas更强大,也更容易测试,但它们引入了许多新概念,如果您还在学习其他技术(特别是Redux),这可能会有点令人不知所措。

具体来说,在处理简单有效的Redux哲学(actions(literal object)馈入reducer(pure functions))的同时,可以用更有限但容易掌握的Thunk(< code > promise . then())来处理副作用。error()),或者使用Saga,这需要您面对(强大的)概念,即您可以使用这些操作做更复杂的事情。

还值得一提的是(redux-)可观察的有一个更复杂(甚至更强大)的范式来处理副作用,以防你不熟悉它(如果你已经熟悉了,它可能比学习佐贺更容易使用)。

 类似资料:
  • 问题内容: 两者都意味着空间,但是有什么区别吗? 问题答案: 一个是不间断空间,另一个是常规空间。不间断的空格表示该行不应在该点处换行,就像它不会在一个单词的中间换行一样。 此外,正如斯文德(Svend)在其评论中指出的那样,不间断的空间不会崩溃。

  • 本文向大家介绍<%# %> 和 <% %> 有什么区别?相关面试题,主要包含被问及<%# %> 和 <% %> 有什么区别?时的应答技巧和注意事项,需要的朋友参考一下 答:<%# %>表示绑定的数据源 <%%>是服务器端代码块  

  • 问题内容: 以下代码之间有什么区别: 和 Python建议采用一种做事方式,但有时似乎不止一种。 问题答案: 一个是函数调用,一个是文字: 使用第二种形式。它更具Python风格,并且可能更快(因为它不涉及加载和调用单独的函数)。

  • 发展至今(2020 年 6 月份),GCC 编译器已经更新至 10.1.0 版本,其功能也由最初仅能编译 C 语言,扩增至可以编译多种编程语言,其中就包括 C++ 。 除此之外,当下的 GCC 编译器还支持编译 Go、Objective-C,Objective-C ++,Fortran,Ada,D 和 BRIG(HSAIL)等程序,甚至于 GCC 6 以及之前的版本还支持编译 Java 程序。但本

  • 问题内容: 比较PMD和CheckStyle有一个问题。但是,我找不到关于PMD和FindBugs之间差异/相似性的详尽分类。我相信一个关键的区别是PMD适用于源代码,而FindBugs适用于编译的字节码文件。但是就功能而言,这应该是一个选择,还是两者相辅相成? 问题答案: 我同时使用。我认为他们是相辅相成的。 正如您所说,PMD在源代码上工作,因此会发现诸如以下问题:违反命名约定,缺少花括号,放

  • 问题内容: 我被要求在portlet和门户网站上工作。 我想知道portlet和servlet之间的区别吗? Portlet与Servlet有何不同之处(可能在功能上)? 问题答案: Portlet是JSR-168标准的一部分,该标准规范门户容器和组件。这与Web容器(和Servlet)的标准不同。尽管这两个标准之间肯定有很强的相似之处,但是它们在容器,API,生命周期,配置,部署等方面有所不同。

  • 问题内容: 精通PHP但学习Java的人应该知道的PHP与Java之间的主要区别是什么? 编辑: 我的意思是这些语言的语法上的差异,即它们的数据类型,它们如何处理数组和引用变量等等:) 问题答案: 这不是一个详尽的清单,我是PHP开发人员,前一段时间做过Java之旅,所以做了Caveat Emptor。 Java中的每个变量都必须以数据类型开头。这包括基本类型,例如boolean,int,doub

  • 问题内容: 的和的方法有什么区别? 任何人都可以通过实时示例来举例说明这些方法以及最佳用法吗? 问题答案: 重定向是一种发送回客户端的响应,而转发委托完全在服务器端进行,转发操作的结果将返回给客户端,就好像它仅来自原始URL。 另一个区别是前向委派只能用于应用程序内资源,而重定向命令可以将客户端浏览器重定向到当前域之外。 例子: 在这里可以找到另一个很好的解释: sendRedirect()和fo