javascript – 为什么捕获行为像解决方案?

我无法解释为什么这段代码执行如下:

>“无法访问服务器”
>“成功:数据已加载”

为什么在无处可能出现解决时调用loadData().then()?

我意识到我可以通过在第一个catch中抛出错误来“修复”代码,以便最后/更高的catch会看到错误.但我想知道显然解析我的代码的人或者是谁,导致在这种情况下达到.then().

是不是在第一个被认为是re​​solve()的catch中重新抛出错误,因为这段代码暗示它是什么?

或者我在这里失踪的Promises的行为怎么样?

function doGoogleRequest(){
    return new Promise(function(resolve, reject){
        reject("Could not reach server.");
    });
}

function loadData(){
    return doGoogleRequest()
        .then(function(data){
            return data;
        }).catch(function(err){
            console.error(err);
        });
}

loadData()
  .then(function(){
    console.log("Success: Data has been loaded.");
}).catch(function(err){
    console.log("Error: could not load data");
});

解决方法:

您正在捕获错误,这表示有意处理它.由于您不再“重新抛出”它,您的代码假定您以适当的方式处理它并且它不再是错误.

这与try..catch完全相同.如果你发现错误并且没有重新抛出它,它下面的代码(或调用代码)将继续运行.

如果从loadData Promise链中删除catch,它将按预期工作.

function doGoogleRequest(){
    return new Promise(function(resolve, reject){
        reject("Could not reach server.");
    });
}

function loadData(){
    return doGoogleRequest()
        .then(function(data){
            return data;
        });
}

loadData()
  .then(function(){
    console.log("Success: Data has been loaded.");
}).catch(function(err){
    console.log("Error: could not load data");
});

相关文章

最后的控制台返回空数组.控制台在ids.map函数完成之前运行va...
我正在尝试将rxJava与我已经知道的内容联系起来,特别是来自J...
config.jsconstconfig={base_url_api:"https://douban....
我正在阅读MDN中的javascript,并且遇到了这个谈论承诺并且不...
config.jsconstconfig={base_url_api:"https://douban....
这是我的代码main.cpp:#include<string>#include<...