ReactJS和Promise:那么如何在里面调用catch呢



所以,我有一个动作创建者(它返回一个函数-我使用redux-thunk)。在创建者返回的函数中,我调用一个dispatch方法,并将thencatch方法链接起来。下面是它的样子:

export function actionCreator(someData) {
(dispath, getState) => {
return dispatch(someAction)
.then(resp => {
//do something
// GO TO CATCH
})
.catch(err => {
return err;
})
}
}

你看到那边的评论了吗?那么,我怎么才能从那里去接球区呢?

谢谢!

如果您想从.then()的主体跳到以下.catch(),最简单的方法是抛出错误:

throw new Error('I meant to blow up here.');

您抛出的错误将传递给.catch()(在您的情况下是err变量)的主体。

请注意,您的示例看起来已经可疑:您的catch块正在捕获一个错误,然后返回,就好像该错误是一个常规值一样,这意味着任何基于上游承诺的处理都将假设调度成功。你确定这就是你想要的吗?

最新更新