Promise统一异常处理

现在前端和后端的交互过程中,很多时候都使用fetch和promise。
例如一个简化版本的从后台取得数据的方法如下

function getData(url) {
  return fetch(url).then(response => {
    if (response.ok) {
      return response;
    } else {
      throw new Error('error');
    }
  });
}

然后在其他地方调用即可


getData('projects').then(data => {
  console.log(data);
});

getData('users').then(data => {
  console.log(data);
});

但是上面没有对异常进行处理,为了进行方便的统一异常处理,可以修改返回的promise对象的then方法,自动将统一的错误处理handler加入。

function onError() {
  console.log('global error handler');
}

function getData(url) {
  const promise = fetch(url).then(response => {
    if (response.ok) {
      return response;
    } else {
      throw new Error('error');
    }
  });
  promise.oldThen = promise.then;
  promise.then = (onFulfilled, onRejected) => {
    return promise.oldThen(onFulfilled, onRejected || onError);
  };

  return promise;
}

调用的时候可以选择自定义的handler还是使用默认的

getData('projects').then(data => {
  console.log('use data' + data);
});

getData('roles').then(data => {
  console.log('use data' + data);
});

getData('users').then(data => {
  console.log('use data' + data);
}, () => {
  console.log('do my self');
});
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • title: promise总结 总结在前 前言 下文类似 Promise#then、Promise#resolv...
    JyLie阅读 14,204评论 1 21
  • Promise 对象 Promise 的含义 Promise 是异步编程的一种解决方案,比传统的解决方案——回调函...
    neromous阅读 12,773评论 1 56
  • 一、Promise的含义 Promise在JavaScript语言中早有实现,ES6将其写进了语言标准,统一了用法...
    Alex灌汤猫阅读 4,237评论 0 2
  • 目录:Promise 的含义基本用法Promise.prototype.then()Promise.prototy...
    BluesCurry阅读 5,321评论 0 8
  • Prepending(进行时),Resolve(成功了),Reject(失败了),then......等 1.Pr...
    _菩提本无树_阅读 49,303评论 0 21