java执行es6_ES6承诺 - 为什么从catch()抛出并从then()抛出的行为不一样?

我有这个ES6代码调用java后端 . java后端通常返回状态代码200和json有效负载,但有时返回状态代码500和json有效负载 . 对于200,我想反序列化json并将结果对象传递给promise链 . 对于500我想要反序列化json并将结果对象抛出promise链,即让它击中catch块 .

以下代码几乎完全符合我的要求:

invoke(className, methodName, args) {

return this.httpClient

.fetch('/api/' + className + "/" + methodName,

{

method: 'POST',

body: json(args)

})

.catch(response => {

// Function A

throw response.json();

})

.then(response => {

// Function B

return response.json();

});

}

this.invoke("TestService", "testMethod", {a: 1, b: 2})

.then(response => {

// Function C

console.log(response); // prints the actual json object which I expect

}).catch(response => {

// Function D

console.log(response); // prints: [object Promise]

});

函数A被调用500.好 .

函数B被调用为200.好 .

response.json()返回A和B中反序列化对象的承诺 . 好 .

函数A导致调用函数D.好 .

函数B导致调用函数C.好 .

函数C的参数,响应是反序列化的对象 . 好 .

But ,函数D中的参数,响应不是反序列化的对象,而是反序列化对象的承诺 .

我已经在这方面工作了一段时间,但我很难解释谷歌我的问题是什么 .

Question: 为什么返回一个承诺'unwrap'下一个函数的承诺,但抛出一个承诺将承诺本身传递给下一个函数?

有没有什么方法可以实现我想要的,这是函数D得到'解包'对象就像函数C一样?

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值