学习 JavaScript 的 async/await

async/await 在JavaScript中作为AsyncFunction的关键字,是ES7提出的基于promise解决js中异步问题的所谓终极方案。其实是Generator函数的语法糖。

在使用async/await 之前,需要知道这个关键字在ie全系列浏览器都是不支持的,具体如下。

1、字面意思

根据命名来粗略的进行理解:

async:异步;

await: 是async wait的缩写,可以理解成等待异步的意思。

2、实际含义

async:函数的修饰符,用于声明该函数是一个异步函数(基于promise的),会默认返回Promise对象,如果该函数有返回值,则会调用Promise.reslove()方法将返回值进行reslove,所以对于async函数也可以直接调用then方法。

注:如果该函数没有返回值,则会resolve一个undefined。

async function tryAsync(){
    return 'I`m Async';
}
const testResult = tryAsync();

console.log(testResult);        // 输出一个状态为fullfield的Promise对象

tryAsync().then(res=>{
    console.log(res);           // I`m Async
})

await:也是修饰符,只能放在async定义的函数内。

await在等什么?通俗来讲,await后面修饰的内容,即为await等待的东西,可以是一个Promise,也可以是任意其他的表达式。

有什么区别呢?如果它等的不是一个 Promise 对象,那 await 表达式的运算结果就是它等到的东西。如果是一个 Promise 对象,它会阻塞后面的代码(仅async内部的代码),等着 Promise 对象 resolve,然后得到 resolve 的值,作为 await 表达式的运算结果,如果Promise无法reslove而是进行了rejected,那么可以用try catch对await进行处理。 

async function fun() {
    let a = await "a";
    let b = await new Promise((resolve, reject) => {
      setTimeout(function () {
        resolve("b");
      }, 2000);
    });

    let c;
    try {
      c = await new Promise((resolve, reject) => {
        setTimeout(function () {
          reject("c");
        }, 2000);
      });
    } catch {
      c = "err";
    }

    let d = await (function () {
      return "d";
    })();
    console.log(a, b, c, d);
  }
  fun();
  console.log(123);

3、为什么async/await是处理异步的终极方案

简单比较下async/await 和 Pormise的区别

  function timeMachine(second) {
    return new Promise((resolve) => {
      setTimeout(() => resolve(second), second * 1000);
    });
  }
  // promise
  timeMachine(1).then((res) => {
    console.log(res);
  });

  // async/await
  async function tryTimeMachine() {
    let res = await timeMachine(1);
    console.log(res);
  }
  tryTimeMachine();

这个时候会发现,普通的promise调用语法甚至更简洁,但是当出现了多个Promise组成的链式调用时,async/await就能展示出他的优势。

  // 需要链式调用多个promise时候
  function checkNumber(n) {
    return new Promise((resolve, reject) => {
      setTimeout(() => {
        if (n < 3) resolve({ status: true, data: n + 1 });
        else reject({ status: false, data: n + 1 });
      }, 1000);
    });
  }

  // 1、写在then里
  checkNumber(1).then((res) => {
    console.log(res);
    checkNumber(res.data).then((res) => {
      console.log(res);
      checkNumber(res.data)
        .then((res) => {
          console.log(res);
        })
        .catch((err) => {
          console.log(err);
        });
    });
  });

  // 2、链式调用
  function commonCheck(n) {
    return checkNumber(n);
  }
  function doCommonCheck(n) {
    commonCheck(n)
      .then((res) => commonCheck(res.data))
      .then((res) => commonCheck(res.data))
      .then((res) => console.log(`结果:${JSON.stringify(res)}`))
      .catch((err) => {
        console.log(err);
      });
  }
  doCommonCheck(1);

  // 3、async/await
  async function asyncCommonCheck(n) {
    const res1 = await checkNumber(n);
    const res2 = await checkNumber(res1.data);
    let res3;
    try {
      res3 = await checkNumber(res2.data);
    } catch {
      res3 = "error";
    }
    console.log(`结果:${JSON.stringify(res3)}`);
  }
  asyncCommonCheck(1);

除此之外,如果需要同时处理多个异步的返回结果,可以使用Promise.all()

  // 同时需要处理多个promise
  async function allAsync1(db) {
    let arr = [1, 2, 3];
    let promises = arr.map((doc) => checkNumber(doc));
    let results = await Promise.all(promises);
    console.log(results);
  }
  allAsync1();
  //
  async function allAsync2(db) {
    let arr = [1, 2, 3];
    let promises = arr.map((doc) => checkNumber(doc));

    let results = [];
    for (let promise of promises) {
      results.push(await promise);
    }
    console.log(results);
  }
  allAsync2();

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: JavaScriptasync/await 是用来处理异步操作的一种语法糖。它允许我们在异步函数中使用同步的写法。 我们可以使用 async 关键字来声明一个 async 函数,在 async 函数中,我们可以使用 await 关键字来等待一个异步操作的结果。 例如,我们可以使用 async/await 来等待一个 HTTP 请求的响应: ``` async function getData() { const response = await fetch('https://example.com/data.json'); const data = await response.json(); return data; } ``` 使用 async/await 可以让我们使用同步的写法来处理异步操作,这样就可以避免使用回调函数和 Promise.then() 方法了。 注意:async/await 只能在函数中使用,不能在全局作用域中使用。 ### 回答2: JavaScriptasync/await是一种处理异步操作的新特性。它是在ECMAScript 2017(ES8)中引入的,用于简化Promise的使用和处理异步代码的方式。 async/await的使用方式很简单,只需要在一个函数前面加上async关键字,这样就表明该函数是一个异步函数。在异步函数中,我们可以使用await关键字来等待一个Promise对象的完成,并且可以将异步操作的结果直接赋值给一个变量。 使用async/await可以使异步代码看起来更像同步代码,这样可以提高代码的可读性和易维护性。其实现原理是通过将异步操作放在一个微任务队列中,然后在等待异步操作完成的过程中,可以继续执行后续的代码。 在使用async/await时,我们可以使用try-catch语句来捕获异步操作中产生的异常。这使得可以更方便地处理和处理异步操作中的错误。 另外,async/await还支持并行执行多个异步操作。通过使用Promise.all()方法,我们可以将多个Promise对象包装成一个新的Promise对象,然后使用await关键字等待新的Promise对象的完成。 需要注意的是,async/await只能改变异步操作的执行顺序,而不能改变异步操作本身的执行时间。所以在使用时,还是需要注意避免长时间的阻塞操作,以免影响程序的性能和响应速度。 总结来说,JavaScriptasync/await是一种用于简化处理异步操作的语法糖。它使得异步代码更容易阅读和写入,并提供了更方便的错误处理和并行执行多个异步操作的能力。这是一个非常有用的特性,在现代的JavaScript中被广泛使用。 ### 回答3: JavaScript中的async/await是一种用于处理异步操作的编程模式。它是ES8(ECMAScript 2017)中引入的新特性,旨在简化异步编程,使代码更易于理解和维护。 async/await是建立在Promise的基础上的。通过在函数前面加上async关键字,可以将函数声明为一个异步函数。异步函数内部可以使用await关键字来等待一个异步操作的完成,并且返回一个Promise对象。 使用async/await可以避免使用回调函数、嵌套的Promise链和复杂的错误处理。通过async/await,代码可以按照线性的方式书写,并且保持原有的控制流结构。 在使用async/await时,可以使用try/catch块来捕获异步操作中的错误,这样就可以像处理同步操作的错误一样处理异步操作的错误。 一个典型的async/await的用法是在异步函数内部使用await关键字等待另一个异步操作的完成,然后使用得到的结果进行后续的处理。在等待异步操作时,代码会暂停执行,而不会阻塞线程。 总之,JavaScriptasync/await是一种更简洁、易读且易于维护的处理异步操作的编程模式。它提供了一种能够让开发者以线性的方式编写异步代码的方式,并且能够更好地处理异步操作中的错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值