深刻理解Promise系列(四):catch

语法糖

catch 其实是 then(undefined, () => {}) 的语法糖,如下:

let p = Promise.reject("error");

// catch
p.catch(err => {
  console.log("catch " + err); // catch error
});

// then
p.then(undefined, err => {
  console.log("catch " + err); // catch error
});

捕获错误

Promise对象内部其实自带了try catch,当同步代码发生运行时错误时,会自动将错误对象作为值reject,这样就会触发catch注册的回调,如下:

let p = new Promise((resolve, reject) => {
  throw "error";
});

p.catch(err => {
  console.log("catch " + err); // catch error
});

但需要注意的是:

  1. 异步代码的运行时错误无法被自动 reject 进而被 catch 捕获,而是直接报错:
let p = new Promise((resolve, reject) => {
  setTimeout(() => {
    throw "error";
  }, 0);
});

p.catch(err => {
  console.log("catch " + err); // 不会被执行
});

关于异步错误是否会被 catch 捕获其实还有点坑,事实证明之所以 setTimeout 中产生的错误不会被 catch 捕获到,原因是 js 的事件队列中,Promise 的 catch 会在 setTimeout 回调之前执行;但是若异步操作抛出错误的回调是在 Promise 的 catch 之前执行的,其实还是可以被 catch 所捕获到的,比如 Promise 的 then 方法所抛出的错误:

let p = Promise.resolve();

let p1 = new Promise(function (resolve, reject) {
  p.then(()=>{
    throw 123;
  }).catch(e => {
    reject(e);
  });
});

p1.catch(err => {
  console.log(err); // 123,错误成功被捕获
});

  1. 一旦 Promise 对象已经 resolve,其后的运行时错误将被忽略:
let p = new Promise((resolve, reject) => {
  resolve();
  throw "error";
});

p.catch(err => {
  console.log("catch " + err); // 不会被执行
});

return的值

与 then 方法相同,执行后会 return 一个新的 Promise 对象,以实现链式调用,你可以显式的 return 一个 Promise 对象,若不显式的 return 则会 return 一个以 undefined 值 resolve 的 Promise 对象;

let p = Promise.reject("error");

// catch
p.catch(err => {
  console.log("catch " + err); // catch error
  // 这里会默认return Promise.resolve(undefined);
}).then(res => {
  console.log(res); // undefined
});

let p2 = Promise.resolve("success");

// then
p2.catch(err => { // 由于p2正常resolve,所以此处不会执行
  console.log("catch " + err);
}).then(res => { // 由于前一个catch未执行,所以此处调用then的还是p2
  console.log(res); // success
  // 这里会默认return Promise.resolve(undefined);
}).then(res => {
  console.log(res); // undefined
});
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Promiese 简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果,语法上说,Pr...
    雨飞飞雨阅读 3,472评论 0 19
  • 官方中文版原文链接 感谢社区中各位的大力支持,译者再次奉上一点点福利:阿里云产品券,享受所有官网优惠,并抽取幸运大...
    HetfieldJoe阅读 11,084评论 26 95
  • //本文内容起初摘抄于 阮一峰 作者的译文,用于记录和学习,建议观者移步于原文 概念: 所谓的Promise,...
    曾经过往阅读 1,310评论 0 7
  • Promise 的含义 一句话概括一下promise的作用:可以将异步操作以同步操作的流程表达出来,避免了层层嵌套...
    雪萌萌萌阅读 5,635评论 0 7
  • 智能手机的出现随时而来就是各种手机党,捏捏族,低头族,说的就是天天手机不离手的人,好似我们一刻不动手机就感觉生活少...
    紫菜姐阅读 520评论 0 2

友情链接更多精彩内容