在createStore之前加载数据

2023-12-04

我创建了一些 React 文件,其中初始化了 Redux 存储。但是,我确实需要在初始化存储之前从 json 文件加载一些数据。

我尝试导入一个加载 json 结构的脚本,然后将其分配给 createStore 初始状态值。但 createStore 在数据加载和分配之前运行。

有没有什么简单的方法可以说“在我的 axios 调用完成之前不要做任何事情”???


动作类型 动作类型.js

export const LOAD_DATA_REQUEST='LOAD_DATA_REQUEST';
export const LOAD_DATA_SUCCESS='LOAD_DATA_SUCCESS';
export const LOAD_DATA_ERROR='LOAD_DATA_ERROR';

Actions

动作.js

import * as Actions from './actiontypes';

function load() {
    return { type: Actions.LOAD_DATA_REQUEST };
}

function success(res) {
    return { type: Actions.LOAD_DATA_SUCCESS, payload: res };
}

function error(ex) {
    return { type: Actions.LOAD_DATA_ERROR, payload: ex };
}
export function loadData(url) {
    return (dispatch) => {
        dispatch(load());
        axios.get(url).then((res) => {
            dispatch(success(res));
        }).catch((ex) => {
            dispatch(error(ex));
        });
    };
}

在需要的减速器中使用它

import * as Actions from './actiontypes';
const newState = Object.assign({}, state);
switch (action.type) {
    case Actions.LOAD_DATA_REQUEST:
        {
            //maybe you load
            newState.loading = true;
            return newState;
        }
    case Actions.LOAD_DATA_SUCCESS:
        {
            const res = action.payload;
            //do what you need  for this reducer

            return newState;
        }
    case Actions.LOAD_DATA_ERROR:{
         /// maybe you will want to show some error message in some reducer? 
        return newState; 
    }
}

您只需要在应用程序的第一个屏幕上的 componentWillMount() 上调用 loadData() 操作

我希望这可以帮助你

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在createStore之前加载数据 的相关文章

随机推荐

  • c函数返回静态变量

    我有一个关于 C 函数如何返回静态变量的问题 in data h file include
  • AtomicInteger 类中 addAndGet 的实现

    我正在浏览 Java Java 6 源代码addAndGet方法中的AtomicInteger class 对应的代码如下 public final int addAndGet int delta for int current get i
  • Cmd - 获取变量名中的变量

    我有一个问题variable in variable 代码如下 set a 1 set b a echo b 预期结果是 1 As a被分配给变量b and 1被分配给变量a 另外 还有一种情况 set b a set a1 100 set
  • 地区/次地方:列表或如何使用 Google API

    我正在拼命寻找世界上所有城市的地区或次地区的列表 数据库 我使用 maxmind com 上的世界所有城市的列表 但是 他们不提供次区域或地区 例如纽约的 曼哈顿 布鲁克林 等 有谁知道某处是否存在解决方案 或者是否有可能使用 Google
  • 如何动态创建菜单项?

    我正在构建一个Android应用程序 我正在尝试构建一个用户管理系统 用户可以在其中登录 注销等 我想在用户注销时显示登录菜单项 在用户登录时显示注销按钮我怎样才能动态地做到这一点 这是现在的布局文件 menu menu
  • Android 谷歌地图 LocationClient

    我在 Android 应用程序中使用 Google Maps Android API v2 LocationClient http developer android com reference com google android gms
  • 如何使用golang的模板实现级联下拉菜单

    设想 我有一个级联场景 其中第二个下拉列表中的值取决于第一个 我有三个模板 布局 输入 和 内部 Attempt 我正在对 输入 模板中第一个下拉列表的更改进行ajax调用 并坚持处理返回的响应 目前我找到了一种通过替换第二个下拉列表的 h
  • 如何获取 JavaScript 中所有可能的字符?

    假设 JavaScript 中的所有字符都是a b c d e and f 我想做的是在字符之间创建随机映射 所以上面的内容可能是这样的 a e b b c e d b e a f c 首先 如何获取 JavaScript 中所有可能的字符
  • ios 8 交互式通知不显示操作

    这是我为 ios8 注册交互式通知的代码 void registerInteractiveNotifications UIMutableUserNotificationCategory corideInviteCategory self c
  • 不可变对象和延迟初始化。

    http www javapractices com topic TopicAction do Id 29 上面是我正在看的文章 不可变对象极大地简化了您的程序 因为它们 允许 hashCode 使用延迟初始化 并缓存其返回值 谁能帮我解释
  • 具有架构优化的 Docker 镜像?

    一些库 例如 BLAS LAPACK 或某些优化库 会在编译时针对本地计算机架构进行优化 让我们以 OpenBlas 为例 使用 OpenBlas 创建 Docker 容器有两种方法 使用 Dockerfile 在其中指定 OpenBlas
  • 什么是替代 BinaryFormatter 的良好内存保护序列化器? [关闭]

    Closed 这个问题是基于意见的 目前不接受答案 我正在使用 Net v3 5 和 C Visual Studio 2008 来处理一个大型应用程序 该应用程序使用BinaryFormatter创建数据文件 Stream stream F
  • 神经网络精度优化

    我在 keras 中构建了一个 ANN 它有 1 个输入层 3 个输入 1 个输出层 1 个输出 和两个隐藏层 分别有 12 个和 3 个节点 我构建和训练网络的方式是 from keras models import Sequential
  • 如何停止nsthread

    我正在使用线程在应用程序的后台更新消息 该线程在我的消息类中启动 消息 m timerThread NSThread alloc initWithTarget self selector selector startTimerThread
  • 克隆密码中带有斜杠的存储库

    克隆存储库可以通过以下方式完成 git clone https username email protected username repository git 但是 当密码包含正斜杠时 这不起作用 错误是 error Couldn t r
  • 无法执行目标 org.codehaus.mojo:exec-maven-plugin:1.6.0:java

    我正在尝试使用 pom xml 文件执行 testNG 主类 方法是使用以下命令Maven 运行配置 exec java Dexec mainClass com selenium controls TestNGMainClass 在这里 我
  • 插入带有标签的行时的 Tkinter Treeview 问题

    我刚刚从 python 3 6 切换到 python 3 7 我有一个函数 可以在 Treeview 树中插入带有标签的行 这些标签用于为插入到树中的行提供前景色和背景色 当我使用 python 3 6 时 我的代码工作正常 一旦我切换到
  • 使用 Discord.js 使用 Discord 机器人将语音频道中的所有人静音

    我本来想在我的机器人不和谐中添加一个功能 当我启动订单时 可以改变语音休息室中的每个人 但我不知道如何做 我的机器人是使用 Node js 和 Discord js 进行编程的 有人能帮我吗 谢谢 我的代码 const Discord re
  • Spring security oauth2 登录和资源服务器在同一应用程序中

    我有一个应用程序 用户 应用程序可以使用 OpenID 提供商或 JWT 令牌进行身份验证 这是我的 spring 安全配置类 EnableWebSecurity public class SecurityConfiguration ext
  • 在createStore之前加载数据

    我创建了一些 React 文件 其中初始化了 Redux 存储 但是 我确实需要在初始化存储之前从 json 文件加载一些数据 我尝试导入一个加载 json 结构的脚本 然后将其分配给 createStore 初始状态值 但 createS