await-to-js 源码解读

1. 前言

本文参加了由公众号@若川视野 发起的每周源码共读活动,点击了解详情一起参与。 **这是源码共读的第21期,链接:juejin.cn/post/708310...

2. await-to-js库了解

通过await-to-js库,就可以在使用async 和await的时候轻松处理错误信息

如下示例

javascript 复制代码
import to from 'await-to-js';
async function test() {
  // 1. try...catch捕获错误
  try{
    const user = await UserModel.findById(1);
  }catch(e) {
    return cb('No user found');
  }

  // 2使用Promise.catch捕获错误
  const res = await UserModel.findById(1).catch((e) => {
    return cb('No user found');
  });


  // 3. 使用to函数捕获错误
  const [err, user] = await to(UserModel.findById(1));
  if(!user) return cb('No user found');
}

3. 源码解析

源码就封装了一个to方法, 统一处理 Promise 的成功和失败情况

  • 如果 Promise 成功解析(resolved) ,返回 [null, data],其中 data 是解析的值。
  • 如果 Promise 被拒绝(rejected) ,返回 [error, undefined],其中 error 是捕获的错误

这样我们就方便获取err啦~

typescript 复制代码
/**
 * @param { Promise } promise 一个promise传参
 * @param { Object= } errorExt - Additional Information you can pass to the err object  用户传入的额外错误提示
 * @return { Promise }
 */
export function to<T, U = Error> (
  promise: Promise<T>,
  errorExt?: object
): Promise<[U, undefined] | [null, T]> {
  return promise
    .then<[null, T]>((data: T) => [null, data])  // resolved后,err就为null返回
    .catch<[U, undefined]>((err: U) => {
      if (errorExt) {
        const parsedError = Object.assign({}, err, errorExt); // 合并错误信息errorExt
        return [parsedError, undefined]; // 返回[parsedError, undefined]
      }

      return [err, undefined]; // 直接返回[err, undefined]
    });
}

export default to;

4. 总结

虽然是小小的一个封装,但是用处极大

相关推荐
Wetoria9 分钟前
管理 git 分支时,用 merge 还是 rebase?
前端·git
前端开发与ui设计的老司机19 分钟前
UI前端与数字孪生融合新领域:智慧环保的污染源监测与治理
前端·ui
一只小风华~32 分钟前
Web前端开发: :has功能性伪类选择器
前端·html·html5·web
Mr_Mao5 小时前
Naive Ultra:中后台 Naive UI 增强组件库
前端
前端小趴菜056 小时前
React-React.memo-props比较机制
前端·javascript·react.js
摸鱼仙人~7 小时前
styled-components:现代React样式解决方案
前端·react.js·前端框架
sasaraku.8 小时前
serviceWorker缓存资源
前端
RadiumAg9 小时前
记一道有趣的面试题
前端·javascript
yangzhi_emo9 小时前
ES6笔记2
开发语言·前端·javascript
yanlele9 小时前
我用爬虫抓取了 25 年 5 月掘金热门面试文章
前端·javascript·面试