当前位置: 首页 / 技术干货 / 正文
async和await语法的缺点

2023-03-29

await 失败

async和await语法的缺点

  ●async / await

  上述我们已经把 promise 的基础使用掌握了, 但是个人认为, promise 的链式调用仍然会有点小问题

  就是在使用的时候, 过多的链式调用, 对于阅读体验来说, 仍然是有一点小问题, 不利于阅读

  所以我们可以 使用 ES6+ 新推出的 async与await, 使用我的异步代码书写的更像是同步代码一样

  ●注意: 需要配合的必须是 Promise

  ●async 关键字的用法:

  ○直接书写在函数的前面即可, 表示该函数是一个异步函数

  ○意义: 表示在该函数内部可以使用 await 关键字

  ●await 关键字的用法:

  ○必须书写在一个有 async 关键字的函数内

  ○await 后面等待的内容必须是一个 promise 对象

  ○本该使用 then 接受的结果, 可以直接定义变量接受了

  ●常规的 promise 调用方式

  fn()

  .then(function (res) {

  console.log(res);

  })

  .catch(function (res) {

  console.log(res);

  });

  ●利用 async 和 await 关键字来使用

  async function newFn() {

  /**

  * await 是等待的意思

  *

  * 在当前 fn 函数内, await 必须要等到后面的 Promise 结束以后, 才会继续执行后续代码

  */

  const r1 = await fn();

  console.log("第一次: ", r1);

  const r2 = await fn();

  console.log("第二次: ", r1);

  const r3 = await fn();

  console.log("第三次: ", r1);

  }

  newFn();

  ●async 和 await 语法的缺点

  ○await 只能捕获到 Promise 成功的状态

  ○如果失败, 会报错并且终止程序的继续执行

  async function newFu() {

  const r1 = await fn();

  console.log("失败后, 提示用户网络错误"); // 如果失败的话这行代码并不会执行

  }

  newFu();

  ● 解决方法1: 使用 try...catch...

  ○语法: try { 执行代码 } catch (err) { 执行的代码 }

  ○首先执行 try 内部的代码, 如果不报错, catch 的代码不执行了

  ○如果报错, 不会爆出错误, 不会终止程序, 而是执行 catch 的代码, 报错信息在 catch 函数的形参内

  async function newFu() {

  try {

  const r1 = await fn();

  console.log(r1);

  } catch (error) {

  console.log("网络错误, 请检查网络并重新请求");

  }

  }

  newFu();

  ●解决方法2: 改变封装的思路

  ○原因: 因为 promise 对象有成功和失败的状态, 所以会在失败状态是报错

  ○解决: 封装一个 百分比成功的 promise 对象, 让成功和失败的时候都按照 resolve 的形式来执行

  ○只不过传递出去的参数, 记录一个表示成功或者失败的信息

  function fn() {

  const p = new Promise(function (resolve, reject) {

  const timer = Math.ceil(Math.random() * 3000) + 2000;

  setTimeout(() => {

  if (timer > 3500) {

  resolve({ code: 0, msg: "班长买水失败" });

  } else {

  resolve({ code: 1, msg: "班长买水成功" });

  }

  }, timer);

  });

  return p;

  }

  async function newFn() {

  const r1 = await fn();

  if (r1.code === 0) {

  console.log("第一次请求失败, 请检查您的网络信息");

  } else {

  console.log("第一次请求成功", r1.msg);

  }

  const r2 = await fn();

  if (r2.code == 0) {

  console.log("第二次请求失败, 请检查您的网络信息");

  } else {

  console.log("第二次请求成功", r2.msg);

  }

  }

  newFn();

好程序员公众号

  • · 剖析行业发展趋势
  • · 汇聚企业项目源码

好程序员开班动态

More+
  • HTML5大前端 <高端班>

    开班时间:2021-04-12(深圳)

    开班盛况

    开班时间:2021-05-17(北京)

    开班盛况
  • 大数据+人工智能 <高端班>

    开班时间:2021-03-22(杭州)

    开班盛况

    开班时间:2021-04-26(北京)

    开班盛况
  • JavaEE分布式开发 <高端班>

    开班时间:2021-05-10(北京)

    开班盛况

    开班时间:2021-02-22(北京)

    开班盛况
  • Python人工智能+数据分析 <高端班>

    开班时间:2021-07-12(北京)

    预约报名

    开班时间:2020-09-21(上海)

    开班盛况
  • 云计算开发 <高端班>

    开班时间:2021-07-12(北京)

    预约报名

    开班时间:2019-07-22(北京)

    开班盛况
IT培训IT培训
在线咨询
IT培训IT培训
试听
IT培训IT培训
入学教程
IT培训IT培训
立即报名
IT培训

Copyright 2011-2023 北京千锋互联科技有限公司 .All Right 京ICP备12003911号-5 京公网安备 11010802035720号