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. 总结

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

相关推荐
一只韩非子2 分钟前
AI时代,程序员如何优雅地搞定页面设计?
前端·ai编程
新中地GIS开发老师7 分钟前
2025Mapbox零基础入门教程(14)定位功能
前端·javascript·arcgis·gis·mapbox·gis开发·地理信息科学
tager10 分钟前
Vue 3 组件开发中的"双脚本"困境
前端·vue.js·代码规范
烛阴1 小时前
Int / Floor
前端·webgl
excel1 小时前
使用 PWA 时,为什么你必须手动添加更新逻辑,否则会报错?
前端
Moment1 小时前
Node.js 这么多后端框架,我到底该用哪个?🫠🫠🫠
前端·后端·node.js
尚学教辅学习资料1 小时前
SpringBoot3.x入门到精通系列: 2.3 Web开发基础
前端·springboot·web开发
han_1 小时前
前端遇到页面卡顿问题,如何排查和解决?
前端·javascript·性能优化
拾光拾趣录3 小时前
H5适配9大高频题连环炸!第3问90%人翻车?
前端·面试
拾光拾趣录3 小时前
给Electron-Claude应用构建全面的数据统计体系 - 从0到1的实践总结
前端·electron