如何让async await错误处理更优雅,如何优雅的做好async await的异常捕获;js util类

本博客js util分类下所有方法都集成在Jsutil库中,Jsutil是一个js util工具类一个功能型函数库


我们在使用async await时如果要处理错误,如果有多个异步操作,需要每一次书写 try...catch。这样代码的简洁性较差,且业务代码需要包含在try...catch中。没办法把业务错误和代码错误分开;

const fn = async ()=>{
  try{
     //请求如果出错,会抛出异常
      const res = await  Axios.get('xxxx');

     //如果请求正常,业务代码错误,如下面代码修改了常量的代码错误也会抛出异常;
     const num;
     num = res.user.num + 1;

  }catch(e){
        //异常处理过于杂乱,违反了单一原则。
        alert(e)
  }  


//多个同步业务处理,代码不简洁
  try{
     const res1 = await Axios.get('x1');
     console.log(res1);
  }catch(e){alert(e)}

  try{
       
     const res2 = await Axios.get('x2');
     console.log(res2);

  }catch(e){alert(e)}
}  

 

在工作中还时常看到有小伙伴用法比较奇葩,把async await跟then catch一起用;

//获取人员数据
        const getStudentStatistics = async ()=>{
            await Axios.get('xxxxxurl').then(res => {
                res = res || {};
                this.studentStatistics = res;
            }).catch(error => {
                this.$alert(error);
            })
        }

这是我实际工作中发现组内小伙伴些的代码,主要可能还是没完全理解async await导致的;

 

为了让代码更整洁,不出现用法混乱的情况;我在网上找到了有一个小哥的处理还不错:https://zhuanlan.zhihu.com/p/85865426

借鉴了他的方法,稍微做了修改,更加实用:

/**
 * @param {*} promise 异步方法主体
 * @param {*} fromatResult 是否处理成统一格式,不处理则直接返回第一个参数。 true处理,false不处理,默认为true :::
 * @return {error,resutl}  有错误 resutl为null,error为错误体。没错误 error为null result为结果
 */
const toAsyncAwait = (promise, fromatResult = true) => {
    if (!fromatResult) {
        return promise;
    } else {
        return promise.then((res) => ({ error: null, result: res })).catch((err) => ({ error: err, result: null }));
    }
}

const fn = async () => {
    // 业务1 使用error判断
    const { error, result } = await toAsyncAwait(Axios.get('xxx1'));
    if (error) {
        alert(error);
    } else {
        console.log(result);
    }
    // 业务2 使用result判断  使用这种判断的时候注意你的返回结果是不是有为null的时候
    const { error: er, result: res } = await toAsyncAwait(Axios.get('xxx1'));
    if (res) {
        console.log(res);
    } else {
        alert(er);
    }
    // 业务三不管错误
    const { result: r } = await toAsyncAwait(Axios.get('xxx3'));
    if (r) {
        console.log(r);
    }
}


此方法已加入 Jsutil 库里。里面有更多的功能函数供大家使用;

 

posted @ 2021-09-13 15:43  灰色的蓝猫  阅读(2149)  评论(0编辑  收藏  举报