javascript - 在yield调用完成之前yield put被触发

标签 javascript react-native redux redux-saga

我尝试进行 API 调用,但在yield 调用完成执行之前就触发了yield put。这是我的代码:

API.js

function callApi(endpoint, token = null) {
  const fullUrl =
    endpoint.indexOf(API_ROOT) === -1 ? API_ROOT + endpoint : endpoint;

  return axios
    .get(fullUrl, { headers: { Authorization: token } })
    .then(resp => {
      return Object.assign([], resp.data);
    })
    .catch(error => ({ error: error.message || "Something bad happened" }));
}

export const checkOpenRegister = (branchId, userId, token) => {
  console.log("in check open");
  callApi(
    `Branches/${branchId}/registers?filter[where][status]=1&filter[where][userId]=${userId}`,
    token
  );
};

在我的传奇中index.js

function* doCheckAuthInfo() {
  try {
    const user = yield select(getUser);

    if (user.token) {
      yield put({
        type: CHECK_AUTH_INFO_SUCCEED,
        payload: { token: user.token }
      });
      yield put({ type: CHECK_OPEN_REGISTER_REQUESTED });
    } else {
      //redirect to login
      yield put(NavigationActions.navigate({ routeName: "Login" }));
    }
  } catch (error) {
    yield put({ type: CHECK_AUTH_INFO_FAILED, error });
  }
}

function* doCheckOpenRegister() {
  try {
    const user = yield select(getUser);

    const response = yield call(
      checkOpenRegister,
      user.branchId,
      user.userId,
      user.token
    );
    yield put({ type: CHECK_OPEN_REGISTER_SUCCEED, payload: response });
  } catch (error) {
    yield put({ type: CHECK_OPEN_REGISTER_FAILED, error: error.message });
  }
}

function* watchCheckAuthInfo() {
  yield takeLatest(CHECK_AUTH_INFO_REQUESTED, doCheckAuthInfo);
}

function* watchCheckOpenRegister() {
  yield takeLatest(CHECK_OPEN_REGISTER_REQUESTED, doCheckOpenRegister);
}

// use them in parallel
export default function* rootSaga() {
  yield all([
    fork(watchCheckAuthInfo),
    fork(watchCheckOpenRegister)
  ]);
}

在我的传奇中,在函数 doCheckOpenRegister 上,yield PUT 在没有有效负载的情况下触发,但我可以在网络调试器中找到有效负载。

我需要有效负载来触发重定向操作。在这种情况下,当响应中有值时,我需要重定向到主页。

最佳答案

你忘记了从函数 checkOpenRegister 返回 Promise

export const checkOpenRegister = (branchId, userId, token) => {
  console.log("in check open");
  return callApi(
    `Branches/${branchId}/registers?filter[where][status]=1&filter[where][userId]=${userId}`,
    token
  );
};

关于javascript - 在yield调用完成之前yield put被触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48296992/

相关文章:

android - Android 上的 React Native Facebook SDK 初始化

javascript - 存储字段的共享方法

javascript - Wordpress Ajax 登录系统出现问题 - 302

javascript - Google Apps 脚本 - 上传文件并将数据发布到电子表格

javascript - 如何在 React Native 中渲染对象?

javascript - React Hooks - useDidUpdateEffect 深度比较

javascript - 使用随机键在对象数组中查找索引

javascript - 带 rails 的主干 - 包括订单

redux - 使用 redux 和 react-navigation

javascript - 我如何从react中的redux状态中提取数据