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

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.kler.cn/a/608367.html

相关文章:

  • 数据库基础知识点(系列五)
  • 分数线划定(信息学奥赛一本通-1180)
  • 关于跨域问题(本地前端访问服务器端接口跨域出错)
  • 解析信息归属地与网络安全的关联
  • 重复出现的数字
  • 无人机中继传输数据链技术,(无人机+自组网)远距离传输技术实现详解
  • Taro 深度解析:跨端框架的设计哲学与实践精髓
  • 智能巡检与预警保障电网安全
  • 开源视频剪辑工具,无损编辑更高效
  • position 属性的值有哪些及其区别
  • PostgreSQL:数据类型与运算符
  • Linux C/C++ 程序的内存泄漏定位方法
  • 使用selenium来获取数据集
  • Java学习总结-Map集合的实现类
  • 算法 | 小龙虾优化算法原理,引言,公式,算法改进综述,应用场景及matlab完整代码
  • VMware打开ubuntu正在使用中怎么解决
  • C语言---函数指针 (指向函数的指针)
  • centos 7 部署FTP 服务用shell 脚本搭建
  • 【区块链 + 文化版权】文创链 | FISCO BCOS 应用案例
  • 如何使用 Postman 在线版?新手教程