当前位置: 首页 > news >正文

rudux中间件

Redux-Thunk


❓ 为什么需要 Redux-Thunk?

在没有 Redux-Thunk 的情况下,Redux 的 Action 必须是普通对象,且必须同步派发。这导致以下问题:

  • ​异步操作无法处理:例如 API 请求需要在请求完成后,派发成功或失败的 Action。
  • ​副作用难以管理:如访问本地存储、设置定时器等。

通过 Redux-Thunk,Redux 的 Action可以是一个函数,异步逻辑封装函数中,函数最后返回拿到结果的action对象,给reducer 的switch 用。


它位于 Action 到达 Reducer 之前,可以拦截、处理或增强 Action。


源码极其简单

const thunk = ({ dispatch, getState }) => (next) => (action) => {
  if (typeof action === 'function') {
    // 如果 Action 是函数,执行它并传入 dispatch 和 getState
    return action(dispatch, getState);
  }
  // 否则,交给下一个中间件或 Reducer 处理
  return next(action);
};
  • 如果 Action 是一个普通对象,直接放行,交给后续中间件或 Reducer 处理。
  • 如果 Action 是一个函数,则执行这个函数,并将 dispatch 和 getState 作为参数传递给它。

定义

actions/index.js

export const incrementFather = () => {
  return async dispatch => {
    await delay() // 异步操作
    dispatch({ type: 'FATHER' }) // 分发同步 action
  }
}

使用

import { incrementSon } from '../../store/actions/index'

const handleClick = () => {
  dispatch(incrementSon())
}

action reduxLogger输出 调用两次的原因

在这里插入图片描述


不用 Redux-Thunk ,如何处理异步事件

1:直接在组件中处理异步(适用于简单场景)

缺点:业务逻辑耦合在组件中,难以复用和测试

// 组件中直接处理异步(如 React 组件)
import { useDispatch } from 'react-redux';
import { fetchDataSuccess, fetchDataFailure } from './actions';

const Component = () => {
  const dispatch = useDispatch();

  const handleClick = async () => {
    try {
      const response = await fetch('/api/data');
      const data = await response.json();
      dispatch(fetchDataSuccess(data));
    } catch (error) {
      dispatch(fetchDataFailure(error));
    }
  };

  return <button onClick={handleClick}>Load Data</button>;
};
http://www.dtcms.com/a/91753.html

相关文章:

  • 如何在自己的数据集上跑通DEIM(CVPR2025)
  • 深入理解垃圾收集算法:从分代理论到经典回收策略
  • 全球变暖
  • 答疑解惑:EMC VMAX3 MMCS控制台不定期重启原因分析
  • 浙大:DeepSeek技术溯源及前沿探索
  • 在SpringBoot中整合Mybatis框架
  • 实现极限网关(INFINI Gateway)配置动态加载
  • H2S Probe硫化氢荧光探针它可以通过荧光来检测H2S水平
  • Vue如何利用Postman和Axios制作小米商城购物车----简版
  • 在MFC中使用Qt(二):实现Qt文件的自动编译流程
  • 虚拟机Vmware无法连接网络
  • FFmpeg开发学习:AVFormatContext结构体
  • 【大模型基础_毛玉仁】3.4 Prompt 技巧
  • 深度学习四大核心架构:神经网络(NN)、卷积神经网络(CNN)、循环神经网络(RNN)与Transformer全概述
  • C++的IO流
  • hackmyvm-jan
  • 如何在 React 项目中使用React.lazy和Suspense实现组件的懒加载?
  • Linux进程间的通信
  • 如何将3DMax模型转换到Blender?
  • 51单片机
  • 基于代理(http\https\socks)的网络访问逻辑重定义
  • 基于本人的专利设计三角形式的三组定子和中间的分形转子结构
  • 海外营收占比近4成,泡泡玛特全球化战略迎收获期
  • 33.[前端开发-JavaScript基础]Day10-常见事件-鼠标事件-键盘事件-定时器-案例
  • C++ 继承:面向对象编程的核心概念(二)
  • 中文字符计数器,助力所有python对齐业务(DeepSeek代笔)
  • 青藏高原湖泊的数量越来越多
  • Mem0 Prompt优化
  • 从手机到机器人:vivo 凭借用户主义重构科技价值
  • 旋转式花键在哪些工业领域应用较为广泛?