iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >async和await有什么用
  • 793
分享到

async和await有什么用

2024-04-02 19:04:59 793人浏览 安东尼
摘要

这篇文章将为大家详细讲解有关async和await有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。来看一个简单的场景://假设有4个异步方法要按顺序调用new Pr

这篇文章将为大家详细讲解有关async和await有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

来看一个简单的场景:

//假设有4个异步方法要按顺序调用

new Promise(function(resolve){

    ajaxA("xxxx", ()=> { resolve(); })    

}).then(function(){

    return new Promise(function(resolve){

        ajaxB("xxxx", ()=> { resolve(); })    

    })

}).then(function(){

    return new Promise(function(resolve){

        ajaxC("xxxx", ()=> { resolve(); })    

    })

}).then(function(){

    ajaxD("xxxx");

});  

语法上不够简洁, 我们可以稍微改造一下

//将请求改造成一个通用函数

function request(options) {

    //.....

    return new Promise(....); //使用Promise执行请求,并返回Promise对象

}

//于是我们就可以来发送请求了

request("Http://xxxxxx")

.then((data)=>{

    //处理data

})

然后我们再来重新改造开头的代码

request("ajaxA")

.then((data)=>{

   //处理data

   return request("ajaxB")

})

.then((data)=>{

   //处理data

   return request("ajaxC")

})

.then((data)=>{

   //处理data

   return request("ajaxD")

})

比起之前有了不小的进步, 但是看上去依然不够简洁

如果我能像使用同步代码那样, 使用Promise就好了

于是, async \ await出现了

async function load(){

    await request("ajaxA");

    await request("ajaxB");

    await request("ajaxC");

    await request("ajaxD");

}

await关键字使用的要求非常简单, 后面调用的函数要返回一个Promise对象

load()这个函数已经不再是普通函数, 它出现了await这样"阻塞式"的操作

因此async关键字在这是不能省略的

那么现在看, 这段代码变得异常清秀

代码的编写顺序

代码的阅读顺序

代码的执行顺序

全部都是按照同步的习惯来的

是不是很方便.

到这你已经学会了async和await基本使用方式

下面来简单解释一下它的工作流程

//wait这个单词是等待的意思

async function load(){

    await request("ajaxA");  //那么这里就是在等待ajaxA请求的完成

    await request("ajaxB");

    await request("ajaxC");

    await request("ajaxD");

}

如果后一个请求需要前一个请求的结果怎么办呢?

传统的写法是这样的

request("ajaxA")

.then((data1)=>{

   return request("ajaxB", data1);

})

.then((data2)=>{

   return request("ajaxC", data2)

})

.then((data3)=>{

   return request("ajaxD", data3)

})

而使用async/await是这样的

async function load(){

    let data1 = await request("ajaxA");  

    let data2 = await request("ajaxB", data1);

    let data3 = await request("ajaxC", data2);

    let data4 = await request("ajaxD", data3);

    //await不仅等待Promise完成, 而且还拿到了resolve方法的参数

}

注意当一个函数被async修饰以后, 它的返回值会被自动处理成Promise对象

关于异常处理

async function load(){

    //请求失败后的处理, 可以使用try-catch来进行

    try{

        let data1 = await request("ajaxA");  

        let data2 = await request("ajaxB", data1);

        let data3 = await request("ajaxC", data2);

    } catch(e){

        //......

    }

}

关于“async和await有什么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: async和await有什么用

本文链接: https://www.lsjlt.com/news/84909.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • async和await有什么用
    这篇文章将为大家详细讲解有关async和await有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。来看一个简单的场景://假设有4个异步方法要按顺序调用new Pr...
    99+
    2024-04-02
  • C#中async和await有什么用
    这篇文章将为大家详细讲解有关C#中async和await有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言本文介绍async/Task。在学习该知识点过程中,一定要按照每一个示例,去写代码、执行、...
    99+
    2023-06-20
  • async和await怎么使用
    本篇内容介绍了“async和await怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Eric:如何讲清楚Promiseasync和a...
    99+
    2023-06-03
  • JavaScript Promise与async、await有什么作用
    这篇文章主要介绍“JavaScript Promise与async、await有什么作用”,在日常操作中,相信很多人在JavaScript Promise与async、await有什么作用问题上存在疑惑,小编查阅了各式资...
    99+
    2023-07-05
  • async await的用法是什么
    async/await 是 JavaScript 中用于处理异步操作的关键字组合。async 关键字用于声明一个函数是异步函数,该函...
    99+
    2023-10-07
    async
  • es6中await和async有哪些作用
    今天小编给大家分享一下es6中await和async有哪些作用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们...
    99+
    2024-04-02
  • React应用怎么使用Async和Await
    这篇文章主要介绍“React应用怎么使用Async和Await”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“React应用怎么使用Async和Await”文章能帮助大家解决问题。Async/Awai...
    99+
    2023-06-05
  • async和await实例分析
    本文小编为大家详细介绍“async和await实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“async和await实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。创建static voi...
    99+
    2023-06-17
  • Javascript中promise,async和await的区别是什么
    本文小编为大家详细介绍“Javascript中promise,async和await的区别是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Javascript中promise,async和await的区别是什么”文章能帮助大家解决疑惑...
    99+
    2023-06-29
  • 详解JavaScript Promise和Async/Await
    目录概述四个示例示例1:用生日解释Promise基础知识示例2:一个猜数字的游戏示例3:从Web API中获取国家信息示例4:从Web API中获取一个国家的周边国家列表总结概述 一...
    99+
    2024-04-02
  • js中怎么用async和await实现同步
    这篇“js中怎么用async和await实现同步”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“js中怎么用async和awa...
    99+
    2023-06-29
  • vue的async-await怎么使用
    本文小编为大家详细介绍“vue的async-await怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue的async-await怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。曾经见过为了让钩子...
    99+
    2023-07-04
  • JavaScript中async,await的使用和方法
    JS中 async函数和await 关键字 function hellworld() { return "您好!美好世界!"; } console.log...
    99+
    2024-04-02
  • 避免async await的使用及原理是什么
    这篇文章主要讲解了“避免async await的使用及原理是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“避免async await的使用及原理是什么”吧!谎言和as...
    99+
    2023-07-02
  • NodeJs中怎么使用async和await处理异步
    NodeJs中怎么使用async和await处理异步,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。场景远古时代我们在编写exp...
    99+
    2024-04-02
  • C#使用async和await实现异步编程
    最近在写程序的时候,经常遇到大量需要异步访问的情况,但是对于async和await到底怎么写,还不是非常明确。 1.普通的程序怎么写? class Program { sta...
    99+
    2024-04-02
  • Node.js中async和await关键字如何使用
    本篇内容主要讲解“Node.js中async和await关键字如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Node.js中async和await关键字如何使用”吧!async 和 aw...
    99+
    2023-07-02
  • vue中async-await如何使用
    本篇文章为大家展示了vue中async-await如何使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。曾经见过为了让钩子函数的异步代码可以同步执行,而对钩子函数使...
    99+
    2024-04-02
  • Nodejs新特性async和await的使用详解
    目录1.Es6常见语法的使用2.Async、Await和Promise1.Es6常见语法的使用 1.let、const let:是一个块作用域 if (true) { let...
    99+
    2024-04-02
  • .NET实现异步编程async和await
    await和async是.NET Framework4.5框架、C#5.0语法里面出现的,await和async是语法糖。 注意: 1、async出现在方法的声明里面,任何一个方法都...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作