首页 > web前端 > js教程 > 正文

Redux Action Creators 中的状态访问何时适合您?

Patricia Arquette
发布: 2024-10-21 18:45:29
原创
236 人浏览过

When is State Access in Redux Action Creators Right for You?

在 Action Creators 中访问 Redux 状态:选项和注意事项

在 Redux 中,访问 Action Creators 中的全局存储状态可能是一个有争议的话题。在这里,我们将深入研究动作创建者中状态访问的两种方法,并探讨它们的优缺点。

静态方法

import store from '../store';
export function someAction() {
  return {
    type: SOME_ACTION,
    items: store.getState().otherReducer.items,
  }
}
登录后复制

此方法直接导入商店,依赖于它是一个从模块导出的单例。虽然功能强大,但由于服务器渲染限制,每个请求通常需要单独的存储,因此不鼓励使用。

函数方法

export function someAction() {
  return (dispatch, getState) => {
    const {items} = getState().otherReducer;

    dispatch(anotherAction(items));
  }
}
登录后复制

此方法利用 Redux Thunk 中间件(推荐的技术)。 Thunk 允许操作创建者分派函数而不是普通的操作对象,从而提供对分派和 getState 函数的访问。虽然它需要中间件,但它可以无缝地用于客户端和服务器端渲染。

注意事项

  • Redux Creator 的意见: Dan Abramov 不鼓励实际的状态访问创建者,提倡在缓存数据检查或条件调度等特定场景中选择性使用。
  • Redux 维护者的观点: Mark Erikson 认为在 thunk 中访问状态是可以接受和鼓励的,承认其预期目的。

最终,最佳方法取决于个人应用程序的要求。理想情况下,操作应包含最少的信息;但是,必要时在操作创建器中使用 getState 是可以接受的。考虑这两种方法的优缺点,然后选择最适合您的项目的一种。

以上是Redux Action Creators 中的状态访问何时适合您?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!