async和await

这篇具有很好参考价值的文章主要介绍了async和await。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Node.JS官方文档:https://nodejs.dev/en/

创建异步函数,并返回相关数值:

一般方式创建

/*
    函数直接通过返回Promise成为异步函数
    异步函数:返回promise的函数称之为异步函数
*/ 
function fn(){
    
    return Promise.resolve(10)
}

// 读取结果需要通过then去读取
fn().then(r => {
    console.log(r)
})

通过async方式创建:

/*
    通过async可以快速的创建异步函数
*/

/*
    通过async可以来创建一个异步函数,fn2() 此时就是一个异步函数
        异步函数的返回值回自动封装到一个Promise中返回
*/
async function fn2(){
    return "async返回的数据10"
}

// 读取结果需要通过then去读取
fn2().then(r => {
    console.log(r)
})

在async声明的函数中可以使用await关键字来调用异步函数


/*
    在async声明的异步函数中可以使用await关键字来调用异步函数
*/


// 创建一个函数计算 a + b的结果,但是异步,即返回的Promise
function sum(a, b){
    return new Promise(resolve => {
        setTimeout(() => {
            resolve(a + b)
        }, 2000)
    })

}

// 通过async创建一个异步函数
async function fn3() {
    sum(123, 456).then(r => {
        console.log(r)
    })

}

// 调用fn3()
fn3()
  • 当我们通过await去调用异步函数时候,它会暂停代码的运行
  • 直到异步代码执行有结果时,才会将结果返回
  • 注意 await只能用于 async声明的异步函数中,或者es模块的紧急作用域中
  • await阻塞的只是异步函数内部的代码,不会影响外部代码
  • 通过 await 调用异步代码时,需要通过try-catch来处理异常
/*
    在async声明的异步函数中可以使用await关键字来调用异步函数
*/


// 创建一个函数计算 a + b的结果,但是异步,即返回的Promise
function sum1(a, b){
    return new Promise(resolve => {
        setTimeout(() => {
            resolve(a + b)
        }, 2000)
    })

}

/*
    Promise解决了异步调用中回调函数问题
        虽然通过链式调用解决了回调地狱,但是链式调用太多以后还是不好看
        但现在要求以同步的方式去调用异步的代码
*/
async function fn4() {
    // 链式调用
    // sum1(123, 456)
    //     .then(r => sum(r, 8))
    //     .then(r => sum(r, 8))
    //     .then(r => console.log(r))

    // 当我们通过await去调用异步函数时候,它会暂停代码的运行
    // 直到异步代码执行有结果时,才会将结果返回
    // 注意 await只能用于 async声明的异步函数中,或者es模块的紧急作用域中
    // await阻塞的只是异步函数内部的代码,不会影响外部代码
    // 通过 await 调用异步代码时,需要通过try-catch来处理异常
    
   
    try{

        let result = await sum(123, 456)
        result = await sum(result, 8)
        result = await sum(result, 9)

        console.log(result)
    }catch(e){
        console.log("出错了")
    }
    

    // awwit阻塞的是异步函数内部的代码
    // console.log(123)
    // console.log(222)
    // console.log(333)

}

// 调用fn3()
fn4()

// await不会阻塞外部代码
console.log("外部代码")

如果async声明的函数没有写await,那么它就会依次执行

// 如果async声明的函数中没有写await,那么它里面就会依次执行
async function fn4(){
    console.log(1)
    console.log(2)
    console.log(3)
    console.log(4)
    // 如果有return 
    return 10
}

fn4()


// fn4等价于fn5
function fn5() {
    return new Promise(resolve => {
        console.log(1)
        console.log(2)
        console.log(3)
        console.log(4)
        resolve(10) // return放在resolve中 fn4如果没有返回值,resolve就为空
    })
}

fn5()

console.log(5)  // 执行结果 1 2 3 4 5 1 2 3 4 5 6

使用await调用函数后,await当前函数后的所有代码,会先进入微任务队列

await后的所有代码,都会放入到微任务队列中执行文章来源地址https://www.toymoban.com/news/detail-432310.html

// 同步代码前加await
async function fn6(){
    console.log(111)
    /*
        当我们使用await调用函数后,await当前函数后的所有代码
            会在await当前函数执行完毕后,被列入微任务队列中
    */
    await console.log(112)
    // await后的所有代码,都会放入到微任务队列中执行
    console.log(113)
    
}

fn6()

console.log(222)  // 执行结果为 111 112 222 113

// 等价于

function fn7() {
    return new Promise(resolve => {
        console.log(111)
        // 上面的在此处加了await
        console.log(112)
        
        resolve()
    }).then(r => {
        console.log(113)
    })
}

到了这里,关于async和await的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Nodejs】Node.js开发环境安装

    在命令窗口中输入 node -v 可以查看版本 0.x 完全不技术 ES6 4.x 部分支持 ES6 特性 5.x 部分支持ES6特性(比4.x多些),属于过渡产品,现在来说应该没有什么理由去用这个了 6.x 支持98%的 ES6 特性 8.x 支持 ES6 特性 去 Node.js 的官网下载安装包: 我们也可以下载历史版本。 后续如果

    2024年02月15日
    浏览(60)
  • async/await 的用法

    使用场景 在实际开发中,如果你遇到了等第一个请求返回数据完,再执行第二个请求(可能第二个请求要传的参数就是第一个请求接口返回的数据)这个问题。 代码 方法1: 方法2: 先请求接口1,获取到接口1返回结果后,将其作为接口2的参数,再去请求接口2 1、async 用于申明

    2024年02月07日
    浏览(30)
  • async和await

    Node.JS官方文档:https://nodejs.dev/en/ 创建异步函数,并返回相关数值: 一般方式创建 通过async方式创建: 在async声明的函数中可以使用await来调用异步函数 当我们通过await去调用异步函数时候,它会暂停代码的运行 直到异步代码执行有结果时,才会将结果返回 注意 awa

    2024年02月02日
    浏览(27)
  • async/await 编程理解

    博客参考 Asynchronous Programming in Rust ,并结合其中的例子阐述 async 和 await 的用法,如何使用 async 和 await 是本节的重点。 async 和 await 主要用来写异步代码,async 声明的代码块实现了 Future 特性。如果实现 Future 的代码发生阻塞,会让出当前线程的控制权,允许线程去执行别的

    2024年02月12日
    浏览(32)
  • Node.Js篇 NodeJs使用MongoDB

    目录 介绍 概念解析                   安装 启动时注意事项 NodeJs操作Mongo 介绍 MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。                                                           

    2024年02月09日
    浏览(37)
  • Promise、Async/Await 详解

            Promise是抽象异步处理对象以及对其进行各种操作的组件。Promise本身是同步的立即执行函数解决异步回调的问题, 当调用 resolve 或 reject 回调函数进行处理的时候, 是异步操作, 会先执行.then/catch等,当主栈完成后,才会去调用执行resolve/reject中存放的方法。      

    2024年02月14日
    浏览(30)
  • Async In C#5.0(async/await)学习笔记

    此文为Async in C#5.0学习笔记 方式一:基于事件的异步Event-based Asynchronous Pattern (EAP). 方式二:基于IAsyncResult接口的异步 方式三:回调 方式四:使用Task,尤其是TaskT 共同的缺陷:必须将方法分为两部分 乱如麻的递归 async/await 注意,下面这样操作可能会有隐患,当firstTask有异常时

    2024年01月22日
    浏览(37)
  • 【C#】async和await 续

    在文章《async和await》中,我们观察到了一下客观的规律,但是没有讲到本质,而且还遗留了一个问题: 这篇文章中,我们继续看看这个问题如何解决! 我们再看看之前写的代码: 当时问题是,为啥 Task.Factory.StartNew 可以看到异步效果,而Task.Run中却是同步效果。 那其实是因为

    2024年02月15日
    浏览(29)
  • kotlin协程async与await

    kotlin协程async与await 输出: 3 3072 https://zhangphil.blog.csdn.net/article/details/129265638 https://zhangphil.blog.csdn.net/article/details/129265638 kotlin协程、线程切换,函数方法委托_zhangphil的博客-CSDN博客 runBlocking 内部启动的3个协程做耗时操作,从输出可以看到3个协程交叉并发执行,runBlocking 会等

    2024年02月05日
    浏览(30)
  • async_await 源码分析

    这篇文章主要是分析 async/await 这个语法糖,分析一下 async 和 await 是如何做到异步的。首先,我先抛出两个问题,各位可以先想一下。 await 之后的方法是何时执行,如何执行的? 为什么 await 之后的代码会在不同的线程执行? 要想知道 async/await 是怎么运行的,需要先写一个

    2024年02月12日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包