微任务中的async/await

上篇 循环机制(event loop)之宏任务和微任务

async/await :

  • async 函数执行后返回一个Promise对象

  • await只能写在async函数中(async和await必须要一起使用)

  • await 只能处理promise对象的异步等待,在其他的异步方法时候无效

  • async 函数中使用return返回的内容可以通过then来获取

  • 从本质上讲,await函数仍然是promise

为什么要用await

​ 为了使我们的异步代码,更像同步的代码

一 基本使用

**用法:**首先在 function 前面加 async 用来说明这个函数是一个异步函数,然后在async里面写await

await 等待当前async function语句内部语句的执行 await接受promise返回的成功或者失败的内容,若没有返回值则不继续向下执行

  • 如果asycn里的代码都是同步的,那么这个函数被调用就会同步执行
async function fn(){
  console.log('a')
}
fn()
console.log('b')
//a
//b
  • 在await后面接的这个promsie都是同步的,await还是会等待,而Promise没有返回值(成功或者失败),所以await不会继续向下执行

    好好看下面这题呀!!!

    function fn(){
        return new Promise(resolve=>{
            console.log(1)
        })
    }
    async function f1(){
        await fn();//没有返回结果所以不向下执行
        console.log(2)
    }
    f1()
    console.log(3)
    //1
    //3
    
    
  • fn属于同步的有返回结果,返回失败的结果所以向下继续执行

    function fn() {
      return new Promise((resolve, rej) => {
        console.log(1)
        rej()
      }).then(function (a) {
        console.log(5)
      }, function (a) {
        console.log(4)
      })
    }
    async function f1() {
      await fn(); //同步堵塞 执行完之后再向下执行
      console.log(2)
    }
    f1()
    console.log(3);
    //1
    //3
    //4
    //2

  • sum变量是等着b()这个函数执行完毕才有值的 ,其实await和promise中的 .then()差不多
async function a(y){
    let sum = await b(3,4)
    let c= sum+y;
    console.log(c)
}
function b (x,y){
    return x+y;
}
a(10)

使用promises,异步函数有两个可能的返回值:已解析的值和被拒绝的值。我们可以.then()用于正常情况,.catch()用于特殊情况。

  • 利用try…catch,进行错误处理
async function a(y){
 try{
  let a = await b(3,4)
    let c= a+y;
    console.log(c)
}catch(err){
	console.log(err);
 }
}
function b (x,y){
    return x+y;
}
a(10,)

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 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: JavaScriptasync/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、付费专栏及课程。

余额充值