首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何转换redux-thunk操作,返回使用异步/等待的承诺?

要转换redux-thunk操作,返回使用异步/等待的承诺,可以使用redux-saga来实现。redux-saga是一个用于管理应用程序副作用(例如异步请求、访问浏览器缓存等)的库,它基于Generator函数和ES6的Promise。

下面是转换redux-thunk操作的步骤:

  1. 安装redux-saga库:
  2. 安装redux-saga库:
  3. 创建一个saga文件,例如sagas.js,用于定义saga函数:
  4. 创建一个saga文件,例如sagas.js,用于定义saga函数:
  5. 在根reducer文件中,使用redux-saga的middleware:
  6. 在根reducer文件中,使用redux-saga的middleware:
  7. 在组件中,触发异步操作的action:
  8. 在组件中,触发异步操作的action:

这样,redux-thunk操作就被转换为使用redux-saga来处理异步操作,并返回使用异步/等待的承诺。在saga函数中,可以使用call函数调用异步请求的API,并使用put函数触发成功或失败的action。通过监听对应的action,可以在组件中触发异步操作的action,并在saga函数中处理异步逻辑。

推荐的腾讯云相关产品:腾讯云函数(Serverless Cloud Function),腾讯云数据库(TencentDB),腾讯云对象存储(COS),腾讯云容器服务(TKE),腾讯云人工智能(AI Lab)等。你可以在腾讯云官网上找到这些产品的详细介绍和文档链接。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

如何序列化Js中的并发操作:回调,承诺和异步等待

(可以让程序代码按照指定的顺序先后执行) 最近,JavaScript引入了异步并等待(Aync / Await),这是Es7新增的方法 这些方法不是相互排斥的,而是相辅相成的:异步/等待基于承诺建立,承诺使用回调...中的并发操作:回调,承诺和异步等待\js>node unserialized. js Started async "Install OS:安装操作系统"......将它们连接在一起的工作已经进入主流 为了实现这一点,我们修改了asyncTask来返回一个承诺。 这个怎么用?当异步操作的结果准备就绪时,我们调用promise的resolve回调函数。...首先,我们将main标记为异步函数。接下来,我们将等待异步操作的结果,而不是承诺 await会自动等待函数返回的promise来自行解析。...编写顶级代码时,可以使用promises的then语法代替,也可以将代码封装在标记为异步的自执行函数中 总结 整篇文章主要是针对如何序列化js中的并发操作,其中序列化也就是编码方式,用什么的方式将要用的方式给存起来

3.2K20
  • React---Redux异步action

    一、分析    (1).明确:延迟的动作不想交给组件自身,想交给action (2).何时需要异步action:想要对状态进行操作,但是具体的数据靠异步任务返回。...(3).具体编码: 1).npm add redux-thunk,并配置在store中 2).创建action的函数不再返回一般对象...3).异步任务有结果后,分发一个同步的action去真正操作数据。 (4).备注:异步action不是必须要写的,完全可以自己等待异步任务的结果了再去分发同步action。.../count_reducer' 9 //引入redux-thunk,用于支持异步action 10 import thunk from 'redux-thunk' 11 //暴露store 12 export...action,就是指action的值为函数,异步action中一般都会调用同步action,异步action不是必须要用的。

    85520

    美团前端react面试题汇总

    另外,浏览器爬虫不会等待我们的数据完成之后再去抓取页面数据。服务端渲染返回给客户端的是已经获取了异步数据并执行JavaScript脚本的最终HTML,网络爬中就可以抓取到完整页面的信息。...就是服务端渲染不需要等待js代码下载完成并请求数据,就可以返回一个已有完整数据的首屏页面。...redux异步流中间件其实有很多,当下主流的异步中间件有两种redux-thunk、redux-saga。...redux-observable额外的范式,上⼿简单redux-thunk缺陷:样板代码过多: 与redux本身⼀样,通常⼀个请求需要⼤量的代码,⽽且很多都是重复性质的耦合严重: 异步操作与redux的...时,该action的函数体会自动执行 store.dispatch(action)}(2)使用redux-saga中间件redux-saga优点:异步解耦: 异步操作被被转移到单独 saga.js

    5.1K30

    React saga_react获取子组件ref

    如何处理副作用操作,在redux中选择在发出action,到reducer处理函数之间使用中间件处理副作用。...在有副作用的action和原始的action之间增加中间件处理,从图中我们也可以看出,中间件的作用就是: 转换异步操作,生成原始的action,这样,reducer函数就能处理相应的action,从而改变...比如下面是一个获取商品列表的异步操作所对应的action: export default ()=>(dispatch)=>{ fetch('/api/goodList',{ //fecth返回的是一个...action不易维护的原因: action的形式不统一 就是异步操作太为分散,分散在了各个action中 2.redux-saga写一个hellosaga 跟redux-thunk,redux-saga...3.redux-saga的使用技术细节 redux-saga除了上述的action统一、可以集中处理异步操作等优点外,redux-saga中使用声明式的Effect以及提供了更加细腻的控制流。

    4.5K30

    2022社招react面试题 附答案

    由于JavaScript中异步事件的性质,当您启动API调⽤时,浏览器会在此期间返回执⾏其他⼯作。当React渲染⼀个组件时,它不会等待componentWillMount它完成任何事情。...所有的jsx最终都会被转换成React.createElement的函数调用。...这样做的主要原因是受控组件支持即时字段验证,允许有条件地禁用/启用按钮,强制输入格式。 7、如何避免组件的重新渲染? React中最常见的问题之一是组件不必要地重新渲染。...redux-thunk优点: 体积⼩:redux-thunk的实现⽅式很简单,只有不到20⾏代码; 使⽤简单:redux-thunk没有引⼊像redux-saga或者redux-observable额外的范式...redux-thunk缺陷: 样板代码过多:与redux本身⼀样,通常⼀个请求需要⼤量的代码,⽽且很多都是重复性质的; 耦合严重:异步操作与redux的action偶合在⼀起,不⽅便管理; 功能孱弱:有

    2.1K10

    redux-thunk引发的redux middleware和store enhancer浅析

    本文作者:IMWeb EnjoyChan 原文出处:IMWeb社区 未经同意,禁止转载 项目中使用redux-thunk来解决异步请求的问题,但是为什么要引入redux-thunk来解决异步请求问题...: 第一种方法, 每次调用的时候都传入dispatch参数,十分冗余 第二种方法,植入store依赖,方法依赖于store,这使得代码的迁移性并不友好 鉴于上述,我们再来看看使用redux-thunk...,返回的是对象还是函数,只需要关注传入的参数; 观察ecncapsulateFunc,我们会发现它返回了一个函数,参数传入dispatch,我们称ecncapsulateFunc为thunk函数,关于thunk...不了解的可以戳链接http://www.ruanyifeng.com/blog/2015/05/thunk.html; 对比上述,使用redux-thunk可以帮助我们代码更优雅,封装设计更合理,当然redux-thunk...createStore第三个参数,那么applyMiddleware方法执行后返回了什么呢,查看redux官方文档,看到createStore的使用如下: createStore(reducer, [preloadedState

    1.1K20

    Redux异步解决方案 1. Redux-Thunk中间件

    帮我请求一下接口数据,你发现接口请求是异步的,没有办法等接口数据返回再传递给reducer 这个时候中间件就产生啦。...redux比较常用的中间件有 redux-saga、redux-thunk、redux-promise等 都是为了解决dispatch action异步处理问题 redux中间件 对redux应用实现异步...可以将 thunk 看做 store 的 dispatch() 方法的封装器;我们可以使用 thunk action creator 派遣函数或 Promise,而不是返回 action 对象。...例如:正常请求接口完再使用dispatch去修改状态。但是如果想在dispath -> action里面执行异步操作 就需要thunk 注意,没有 thunk 的话,默认地是同步派遣。...不用直接返回action 这使得里面可以写异步操作 先去请求接口 在去dispatch一个action到reducer // 当应用了thunk中间件时 action creator返回的函数都会默认传递一个

    1.3K20

    一天梳理完react面试高频题

    这种机制可以让我们改变数据流,实现如异步action ,action 过滤,日志输出,异常报告等功能redux-logger:提供日志输出redux-thunk:处理异步操作redux-promise:...处理异步操作,actionCreator的返回值是promise如何配置 React-Router 实现路由切换(1)使用 组件路由匹配是通过比较 的 path 属性和当前地址的...redux异步流中间件其实有很多,当下主流的异步中间件有两种redux-thunk、redux-saga。...redux-observable额外的范式,上⼿简单redux-thunk缺陷:样板代码过多: 与redux本身⼀样,通常⼀个请求需要⼤量的代码,⽽且很多都是重复性质的耦合严重: 异步操作与redux的...时,该action的函数体会自动执行 store.dispatch(action)}(2)使用redux-saga中间件redux-saga优点:异步解耦: 异步操作被被转移到单独 saga.js

    4.1K20

    高频React面试题及详解

    保存数据,数据变化后自动处理响应的操作 redux使用不可变状态,这意味着状态是只读的,不能直接去修改它,而是应该返回一个新的状态,同时使用纯函数;mobx中的状态是可变的,可以直接对其进行修改 mobx...当然mobx和redux也并不一定是非此即彼的关系,你也可以在项目中用redux作为全局状态管理,用mobx作为组件局部状态管理器来用. redux中如何进行异步操作?...但是在一定规模的项目中,上述方法很难进行异步流的管理,通常情况下我们会借助redux的异步中间件进行异步处理. redux异步流中间件其实有很多,但是当下主流的异步中间件只有两种redux-thunk、...redux-thunk优点: 体积小: redux-thunk的实现方式很简单,只有不到20行代码 使用简单: redux-thunk没有引入像redux-saga或者redux-observable额外的范式...,上手简单 redux-thunk缺陷: 样板代码过多: 与redux本身一样,通常一个请求需要大量的代码,而且很多都是重复性质的 耦合严重: 异步操作与redux的action偶合在一起,不方便管理

    2.4K40

    深入理解 redux 数据流和异步过程管理

    异步过程的管理 很多情况下改变 store 数据都是一个异步的过程,比如等待网络请求返回数据、定时改变数据、等待某个事件来改变数据等,那这些异步过程的代码放在哪里呢? 组件?...,takeLatest 会对多个 action 的最后一个做处理,race 会只返回最快的那个异步过程的结果,等等。...这些控制多个异步过程之间关系的 effect 正是 redux-thunk 所没有的,也是复杂异步过程的管理必不可少的部分。...所以做特别复杂的异步流程处理的时候,redux-observable 能够利用 rxjs 的操作符的优势会更明显。...redux-saga 透传了 action 到 store,并且监听 action 执行相应的异步过程。异步过程的描述使用 generator 的形式,好处是可测试性。

    2.5K10

    react知识总结_六年级教学工作总结个人

    大家好,又见面了,我是你们的朋友全栈君。 简介 这次要总结的是对 store 和 reducer 的拓展,比如发送异步的 action 操作,还有一个就是对多个 reducer 的管理。...store 的第三个参数 目前的 store 并不具备处理异步 action 的能力,我们可以使用 中间件 来实现这个操作。...这种异步思路就是使用 Action Creator 返回一个函数,然后使用 redux-thunk 让 dispatch 能够接受一个函数作为参数。...); 上一种方法是使用 Action Creator 返回函数来操作异步,使用 redux-promise 可以让它返回一个 promise 对象,可以使用 then 来实现后面的操作。...redux-promise 让它能够返回一个 使用 promise ,接着我们调用 使用 deleteUserData 函数时就可以执行 then 的操作。

    66520

    深度剖析github上15.1k Star项目:redux-thunk

    dispatch和异步action的问题(虽然这完全依赖于redux的中间件机制(Middleware))。...这里我们并不能在action中处理异步逻辑,这也是redux-thunk的价值之一,即解决异步调用action。...到这一步我们仍然不能直接进入redux-thunk的源码分析,因为我们还是不清楚如何解决上述步骤,因为我们还没有了解redux的中间件机制。...实现中间件的机制也很简单, 就是在框架核心执行流中去遍历外部传入的中间件,并依次执行即可,我们先来看看redux中如何使用中间件的: import { createStore, applyMiddleware...,如果参数大于一时,我们采用reduce将上一个函数返回的结果传给下一个函数参数,以此来实现之间的参数共享和传递,非常经典的设计。

    75720

    redux原来如此简单

    如何能够有条理的管理这些数据,成为前端开发中一个难题。 核心概念 三大原则 单一数据源 使用redux的程序,所有的state都存储在一个单一的数据源store内部,类似一个巨大的对象树。...state是只读的 state是只读的,能改变state的唯一方式是通过触发action来修改 使用纯函数执行修改 为了描述 action 如何改变 state tree , 你需要编写 reducers...只需要根据action,返回对应的state。而且必须要有返回。...Reducer作为纯函数,内部不建议使用任何有副作用的操作,比如操作外部的变量,任何导致相同输入但输出却不一致的操作。...高级应用 异步action 我们也看到了,我们的reducer只能做同步应用,如果我们需要在reducer,做一些延迟操作,可怎么办 社区已经有成熟的类库做这件事件 npm install redux-thunk

    74710
    领券