首页 > web前端 > js教程 > 为什么在 Redux 中使用中间件进行异步操作?

为什么在 Redux 中使用中间件进行异步操作?

Mary-Kate Olsen
发布: 2024-12-27 20:27:10
原创
187 人浏览过

Why Use Middleware for Asynchronous Actions in Redux?

为什么我们需要 Redux 中的异步流中间件?

乍一看,Redux 不支持异步数据流,因为它指定了“Redux 存储仅支持同步数据流。”然而,事实并非如此。

在给定的示例中,容器组件当然可以调用异步 API 并随后分派必要的操作。事实上,这种方法可以正常工作,单击按钮时字段的更新就证明了这一点。

这个策略有什么问题吗?

主要关注点出现在较大的应用程序中,其中许多组件可能执行相同的操作,或者可能需要合并诸如去抖之类的功能。此外,对于自动递增 ID 之类的任务,保留动作创建者附近的本地状态可能是有益的。

从维护的角度来看,它简化了将动作创建者分成不同功能的问题,从而简化了动作创建者的开发和维护代码库。

虽然像 Redux Thunk 或 Redux Promise 这样的中间件通过语法糖提供了代码简化,但对于

没有中间件:

在没有中间件的情况下,action 创建者可以直接执行异步操作,如下所示:

function loadData(dispatch, userId) {
  fetch(`http://data.com/${userId}`)
    .then(res => res.json())
    .then(
      data => dispatch({ type: 'LOAD_DATA_SUCCESS', data }),
      err => dispatch({ type: 'LOAD_DATA_FAILURE', err })
    );
}

// in component
componentWillMount() {
  loadData(this.props.dispatch, this.props.userId); // pass dispatch as argument for async action creator
}
登录后复制

用 Thunk中间件:

Redux Thunk 提供了更简洁的语法来分派异步操作:

function loadData(userId) {
  return dispatch =>
    fetch(`http://data.com/${userId}`)
      .then(res => res.json())
      .then(
        data => dispatch({ type: 'LOAD_DATA_SUCCESS', data }),
        err => dispatch({ type: 'LOAD_DATA_FAILURE', err })
      );
}

// in component
componentWillMount() {
  this.props.dispatch(loadData(this.props.userId)); // dispatch as usual
}
登录后复制

中间件的好处:

主要使用 Redux Thunk 等中间件的优点在于将组件与操作创建者实现细节解耦。组件仍然不知道动作创建者是同步还是异步,以及它是否与 Redux 状态或其他动作创建者交互。

中间件的替代品:

Redux Thunk 是不是 Redux 应用程序中处理异步请求的唯一方法。另一个引人注目的替代方案是 Redux Saga,它可以定义长期运行的“saga”,这些“saga”对传入操作进行操作,在生成进一步操作之前转换或执行请求。

以上是为什么在 Redux 中使用中间件进行异步操作?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板