【学习笔记】在redux中使用axios,通过redux-thunk处理action

异步修改的情况下,我们需要先获取到网络请求的数据,然后通过调用dispatch派发action修改,如果我们需要将网络请求封装在action中应该如何处理?

无论是dispatch还是action也好,都是同步代码,且action只能返回一个对象,所以我们如果在action中封装网络请求会出现无法获取到值的情况,如图:

按图片上面执行的代码,getBannerList 这个action的返回值是undefined

我们如果加上async/await呢?

看起来似乎没有问题,但是这里本质其实是返回 一个 promise 对象,所以报错如下:

我们注意到,报错信息中提示我们如果想处理函数可以使用redux-thunk这个库,那么这个redux-thunk库到底是什么东西呢?又该如何使用呢?

redux-thunk

redux-thunk库其实是一个redux的中间件,底部源码做的事情非常简单,就是当你acton返回的是一个函数的时候帮你执行这个函数,并将dispatch传递给这个函数。

那么如何使用呢?

快速入门

在你创建redux的store的时候可以配置中间件

import { createStore, applyMiddleware } from "redux"
//导入thunk
import thunk from 'redux-thunk'

import reducer from "./reducer"
//createStore第二个参数为添加中间件
const store = createStore(reducer, applyMiddleware(thunk))

export default store

这样我们就配置好了thunk中间件,再回头看看我们的action应该如何修改吧

我们的getBannerListAction现在返回的一个函数,thunk会帮我们执行此次函数并且将dispatch传递给函数,除此之外还好给我们一个getState函数,原来获取state的数据。

0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
redux-thunk是一个用于处理异步操作的Redux间件。它允许我们在Redux编写异步逻辑,并且可以在action creators返回函数而不仅仅是一个普通的action对象。 使用redux-thunk,首先要安装它: ``` npm install redux-thunk ``` 然后,在创建store时将thunk作为middleware应用到Redux store: ```javascript import { createStore, applyMiddleware } from 'redux'; import thunk from 'redux-thunk'; import rootReducer from './reducers'; const store = createStore(rootReducer, applyMiddleware(thunk)); ``` 接下来,你可以在action creators返回一个函数,而不仅仅是一个普通的action对象。这个函数可以接收dispatch和getState作为参数,允许你执行异步操作并在适当的时机分发action。 例如,你可以创建一个异步的action creator来获取数据: ```javascript const fetchData = () => { return (dispatch, getState) => { dispatch({ type: 'FETCH_DATA_START' }); // 异步请求数据并处理响应 fetch('https://api.example.com/data') .then(response => response.json()) .then(data => { dispatch({ type: 'FETCH_DATA_SUCCESS', payload: data }); }) .catch(error => { dispatch({ type: 'FETCH_DATA_FAILURE', payload: error }); }); }; }; ``` 在上面的例子,我们返回了一个函数,该函数接收dispatch和getState作为参数。在函数体内,我们可以执行异步操作(例如发起网络请求),并在适当的情况下分发相应的action使用redux-thunk,你的action creators可以更灵活地处理异步逻辑,并且能够与Redux无缝地集成。希望这个回答对你有帮助!如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值