你如何在Javascript中正确链接承诺,并考虑错误处理?

时间:2016-06-11 16:35:24

标签: javascript promise

我在理解Javascript承诺方面遇到了一些麻烦,特别是将它们链接起来并将错误传递给链条。在以下代码中:

function myPromise() {
  return new Promise((resolve, reject) => {
    setTimeout(function() {
      console.log('done')
      reject('resolved');
    }, 1000);
  });
}

function myOtherPromise() {
  return new Promise((resolve, reject) => {
    myPromise().then(done => {
      resolve(done);
    }).catch(e => {
      console.log('In myOtherPromise, caught err: ', e);
      reject(e)
    });
  });
}

myOtherPromise().then(done => {
  console.log('done calling myOtherPromise: ', done);
}).catch(e => {
  console.log('caught err from myOtherPromise', err);
});

输出显示:

done
In myOtherPromise, caught err:  resolved

我不明白为什么不打印以下内容:

'caught err from myOtherPromise'

我觉得有一些根本我不太了解的东西。为什么不将myOtherPromise的拒绝传递给最终catch块?

1 个答案:

答案 0 :(得分:4)

您将错误捕获到e变量中,但输出err变量(未定义并导致运行时错误)。

.catch(e => {
  console.log('caught err from myOtherPromise', err);
})

应该是:

.catch(e => {
  console.log('caught err from myOtherPromise', e);
})