redux副作用处理之redux-thunk使用

 更新时间:2024年01月25日 09:26:35   作者:Shi Jian Xin  
这篇文章主要介绍了redux副作用处理之redux-thunk使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

一、安装

yarn add redux-thunk
// 或
npm install --save redux-thunk

二、使用

import { createStore, applyMiddleware } from "redux";
import * as loginActions from "./action/login";
import reducer from "./reducer";
import logger from "redux-logger";
import thunk from "redux-thunk";

// 创建仓库
const store = applyMiddleware(thunk, logger)(createStore)(reducer);

三、为什么要使用redux-thunk?

redux中的action都必须要是一个平面对象,所以就不能有任何的副作用,redux-thunk就是为了解决这一问题,使用redux-thunk中间件后,允许action返回一个函数,这个函数是允许有副作用的

例如:

写一个带有副作用的action:

export function setTime(payload) {
  return function () {
    setTimeout(() => {
      console.log("定时器");
    }, 1000);
  };
}

如果没有使用redux-thunk会直接报错显示action必须是一个平面对象

import { createStore, applyMiddleware } from "redux";
import * as loginActions from "./action/login";
import reducer from "./reducer";
import logger from "redux-logger";
import thunk from "redux-thunk";

// 创建仓库
const store = applyMiddleware(logger)(createStore)(reducer);
store.dispatch(loginActions.setTime());

使用了redux-thunk中间件后正常运行

四、redux-thunk运行原理

redux-thunk中间件一般放在第一个,因为它在接收action时如果发现action不是一个平面对象

那么它就不会传递给下一个中间件

它会直接将这个函数运行

如果action是一个平面对象它才会往后传递

五、redux-thunk原理

redux-thunk会返回给action3个参数

  • 1.dispatch:store的dispatch
  • 2.getState:store的getState
  • 3.extraArgument:用户传入的参数

源码:

function createThunkMiddleware(extraArgument) {
  return ({ dispatch, getState }) => next => action => {
    // 如果当前的action是一个函数直接调用该函数
    if (typeof action === 'function') {
      return action(dispatch, getState, extraArgument);
    }

    // 如果当前的action是一个平面对象,传递个下一个中间件
    return next(action);
  };
}

const thunk = createThunkMiddleware();
// 可以使用withExtraArgument传入一个参数
thunk.withExtraArgument = createThunkMiddleware;

export default thunk;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • React Hook中useState更新延迟问题及解决

    React Hook中useState更新延迟问题及解决

    这篇文章主要介绍了React Hook中useState更新延迟问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • React+ResizeObserver实现自适应ECharts图表

    React+ResizeObserver实现自适应ECharts图表

    ResizeObserver是JavaScript的一个API,用于监测元素的大小变化,本文主要为大家介绍了React如何利用ResizeObserver实现自适应ECharts图表,需要的可以参考下
    2024-01-01
  • React创建配置项目的实现

    React创建配置项目的实现

    本文主要介绍了React创建配置项目的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-06-06
  • React实现一个高度自适应的虚拟列表

    React实现一个高度自适应的虚拟列表

    这篇文章主要介绍了React如何实现一个高度自适应的虚拟列表,帮助大家更好的理解和学习使用React,感兴趣的朋友可以了解下
    2021-04-04
  • react实现组件状态缓存的示例代码

    react实现组件状态缓存的示例代码

    本文主要介绍了react实现组件状态缓存的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • react之umi配置国际化语言locale的踩坑记录

    react之umi配置国际化语言locale的踩坑记录

    这篇文章主要介绍了react之umi配置国际化语言locale的踩坑记录,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • 在React中写一个Animation组件为组件进入和离开加上动画/过度效果

    在React中写一个Animation组件为组件进入和离开加上动画/过度效果

    这篇文章主要介绍了在React中写一个Animation组件为组件进入和离开加上动画/过度效果,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-06-06
  • React并发更新与性能优化解析

    React并发更新与性能优化解析

    这篇文章主要为大家介绍了React并发更新与性能优化解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • React项目中服务器端渲染SSR的实现与优化详解

    React项目中服务器端渲染SSR的实现与优化详解

    在传统的 React 项目里,页面的渲染工作是在浏览器里完成的,而服务器端渲染(SSR)则是让服务器先把 React 组件渲染成 HTML 字符串,再把这个 HTML 字符串发送给浏览器,下面我们就来看看具体实现方法吧
    2025-03-03
  • React如何实现视频旋转缩放

    React如何实现视频旋转缩放

    这篇文章主要为大家详细介绍了React如何实现视频旋转缩放功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-11-11

最新评论