javascript - 未处理的拒绝(类型错误): dispatch is not a function getting this error in action creator

标签 javascript reactjs redux-thunk dispatch dispatch-async

我在调用调度时收到此错误。

Unhandled Rejection (TypeError): dispatch is not a function

这是我的 Action 创建者代码,我遇到了上述错误。

export function getStatus(requestId) {
  return async dispatch => {
    let url = GET_UPLOADED_STATUS_URL + requestId;
    let response = await get(url);
    const timeout = setTimeout(getStatus(requestId), 2000);
    if (response.status === 200) {
      let total = response.payload.count;
      let totalCompleted = response.payload.uploadCompleted
      dispatch({
        type: UPDATE_PROGRESS_BAR_STATUS,
        total: total,
        completed: totalCompleted
      })
      if (!response.payload == "") {
        toastr.info(`Total processed ${totalCompleted}`);
      }
      if (response.payload === "") {
        dispatch({
          type: SHOW_PROGRESS_BAR,
          data: false
        })
        clearTimeout(timeout);
      }
    } else {
      clearTimeout(timeout);
      dispatch({
        type: SHOW_PROGRESS_BAR,
        data: false
      });
    }
  }
}

正如您所看到的,我每两秒调用一次此操作。第一次执行时工作正常,但第二次执行时,在调度 UPDATE_PROGRESS_BAR_STATUS 时会出现上述错误。 并在控制台中收到此错误。

Uncaught (in promise) TypeError: dispatch is not a function
    at _callee3$ (index.js:100)

有人可以指导我在这里做错了什么或者为什么我会收到此错误。任何帮助将不胜感激,提前致谢。

这是我更新的代码,其中我如何调用 getStatus() 操作。

export function uploadFileFolder(arrayofFile, jdId) {
  return async dispatch => {
    dispatch({
      type: REQUEST_INITIATED
    });
    let url = UPLOAD_FILE_FOLDER_URL + jdId;
    let response = await post(url, arrayofFile);
    if (response.status === 200) {
      dispatch({
        type: REQUEST_SUCCESSED
      });
      history.push({
        pathname: "/file-list/" + jdId
      });
      toastr.success(response.payload.message);
      dispatch({
        type: SHOW_PROGRESS_BAR,
        data: true
      });
      let requestId = response.payload.requestId;
      dispatch(getStatus(requestId));
    } else {
      dispatch({
        type: REQUEST_SUCCESSED
      });
    }
  }
}

和 uploadFileFolder() 操作我通过单击组件中的按钮来调用它。

最佳答案

您收到此错误是因为当您每 2 秒后调用 getStatus() 操作时,未得到调度。正如您所说,它第一次执行时工作正常,但在第二次调用时出现错误,因为第二次它没有得到调度。因此,您需要更新您的代码,如下所示。

const timeout = setTimeout(dispatch(getStatus(requestId), 2000));

关于javascript - 未处理的拒绝(类型错误): dispatch is not a function getting this error in action creator,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55793235/

相关文章:

redux reducer vs Action

javascript - 如何创建包含文本和图像的幻灯片

javascript - jQuery用阿拉伯数字数组替换英文数字数组

javascript - 如何知道哪个域使用 JS 向我的 C# 操作发送请求

reactjs - 将 React 输入掩码(InputMask)与 formik 一起使用

reactjs - 循环/递归 React PropTypes

javascript - if 语句 JavaScript 中的局部变量

javascript - 无法使用本地存储设置变量

javascript - React Ajax 请求给出 CORS 错误但返回数据

reactjs - 使用多个调度(加载,错误和成功)测试 Action