ES8:async await 更加优雅的异步编程解决方案

2024-03-17 16:18

本文主要是介绍ES8:async await 更加优雅的异步编程解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

async await  

  • async 和 await 是一种更加优雅的异步编程解决方案,是 Promise 扩展
  • async 让我们写起 Promise 像同步操作

async await 基本语法

  • 前面加 async 的函数,在执行后都会自动返回一个 Promise 对象
async function foo() {return 'es'
}
console.log(foo())

  • await 后面需要跟异步操作,否则没有意义
  • await 后面的 Promise 对象不必写 then,因为 await 的作用之一就是获取后面 Promise 对象成功状态传递出来的参数
function timeout() {return new Promise(resolve => {setTimeout(() => {console.log(1)resolve()}, 1000)})
}// 不加 async 和 await 是2、1   加了是 1、2
async function foo() {await timeout()console.log(2)
}
foo()

async await 对失败处理

  • Promise 对象成功状态 fulfilled 和失败状态 rejected 里面的 resolve() 和 reject() 返回的值,只能通过 then() 或 catch() 获取
  • async 函数中使用 await,await 后面跟的代码会变成同步任务,只有等 await 后面的 Promise 执行完成得到结果才会继续下去,await 就是等待的意思
function timeout() {return new Promise((resolve, reject) => {setTimeout(() => {// resolve('success')reject('error')}, 1000)})
}
async function foo() {return await timeout()
}
foo().then(res => {console.log(res)
}).catch(err => {console.log(err) // error
})

案例:需要发送多个请求,后面请求发送总是需要依赖上一个请求返回的数据

  • 既可以用 Promise 链式调用来解决,也可以用 async/await 来解决,后者更简洁
  • await 只能在 async 标记的函数内部使用,单独使用会触发 Syntax error
// 封装 ajax 请求函数
function ajax(url, successCallback, failCallback){let xmlhttpif(window.XMLHttpRequest){xmlhttp = new XMLHttpRequest()} else {xmlhttp = new ActiveXObject('Microsoft.XMLHTTP')}xmlhttp.open('GET', url, true)xmlhttp.send()xmlhttp.onreadystatechange = function(){if(xmlhttp.readyState === 4 && xmlhttp.status === 200){const obj = JSON.parse(xmlhttp.responseText)successCallback(obj)} else if(xmlhttp.readyState === 4 && xmlhttp.status === 404) {failCallback(xmlhttp.statusText)}}
}// 封装 Promise 请求函数
function request(url){return new Promise((resolve, reject) => {ajax(url, res => {resolve(res)}, err => {resolve(err)})})
}const url1 = 'http://jsonplaceholder.typicode.com/users'
const url2 = 'http://jsonplaceholder.typicode.com/todos'
const url3 = 'http://jsonplaceholder.typicode.com/photos1'// 使用 async await 发送请求
async function getData(){const res1 = await request(url1)console.log(res1)const res2 = await request(url2)console.log(res2)const res3 = await request(url3)console.log(res3)
}
getData()

Promise 对象_taoqidejingling的博客-CSDN博客Promise Ajax 请求函数封装;Promise 优势;Promise 内部状态;Promise 原型链方法;Promise 静态方法6个;https://blog.csdn.net/taoqidejingling/article/details/122990974

异步操作前置知识_taoqidejingling的博客-CSDN博客JS 是单线程语言;同步任务和异步任务;Ajax 请求;Callback Hell 回调地狱(回调深渊)https://blog.csdn.net/taoqidejingling/article/details/122984154

这篇关于ES8:async await 更加优雅的异步编程解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/819473

相关文章

Nginx启动失败:端口80被占用问题的解决方案

《Nginx启动失败:端口80被占用问题的解决方案》在Linux服务器上部署Nginx时,可能会遇到Nginx启动失败的情况,尤其是错误提示bind()to0.0.0.0:80failed,这种问题通... 目录引言问题描述问题分析解决方案1. 检查占用端口 80 的进程使用 netstat 命令使用 ss

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

Java下载文件中文文件名乱码的解决方案(文件名包含很多%)

《Java下载文件中文文件名乱码的解决方案(文件名包含很多%)》Java下载文件时,文件名中文乱码问题通常是由于编码不正确导致的,使用`URLEncoder.encode(filepath,UTF-8... 目录Java下载文件中文文件名乱码问题一般情况下,大家都是这样为了解决这个问题最终解决总结Java下

Idea实现接口的方法上无法添加@Override注解的解决方案

《Idea实现接口的方法上无法添加@Override注解的解决方案》文章介绍了在IDEA中实现接口方法时无法添加@Override注解的问题及其解决方法,主要步骤包括更改项目结构中的Languagel... 目录Idea实现接China编程口的方法上无法添加@javascriptOverride注解错误原因解决方

异步线程traceId如何实现传递

《异步线程traceId如何实现传递》文章介绍了如何在异步请求中传递traceId,通过重写ThreadPoolTaskExecutor的方法和实现TaskDecorator接口来增强线程池,确保异步... 目录前言重写ThreadPoolTaskExecutor中方法线程池增强总结前言在日常问题排查中,

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

一文详解Java Condition的await和signal等待通知机制

《一文详解JavaCondition的await和signal等待通知机制》这篇文章主要为大家详细介绍了JavaCondition的await和signal等待通知机制的相关知识,文中的示例代码讲... 目录1. Condition的核心方法2. 使用场景与优势3. 使用流程与规范基本模板生产者-消费者示例

MYSQL事务死锁问题排查及解决方案

《MYSQL事务死锁问题排查及解决方案》:本文主要介绍Java服务报错日志的情况,并通过一系列排查和优化措施,最终发现并解决了服务假死的问题,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录问题现象推测 1 - 客户端无错误重试配置推测 2 - 客户端超时时间过短推测 3 - mysql 版本问