async/await
时间:2022-07-24
本文章向大家介绍async/await,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
async/await
async
是ES7
的与异步操作有关的关键字,其返回一个Promise
对象,await
操作符用于等待一个Promise
对象,它只能在异步函数async function
内部使用。
async
语法
async function name([param[, param[, ... param]]]) { statements }
-
name
: 函数名称。 -
param
: 要传递给函数的参数的名称。 -
statements
: 函数体语句。
async
函数返回一个Promise
对象,可以使用then
方法添加回调函数,返回的Promise
对象会运行执行resolve
异步函数的返回结果,如果抛出异常则运行拒绝reject
。
实例
async function asyncPromise(v){
return v;
}
asyncPromise(1).then((v) => {
console.log(v);
}).catch((e) => {
console.log(e);
})
await
async
一般是配合await
指令使用的,该指令会暂停异步函数的执行,并等待Promise
执行,然后继续执行异步函数,并返回结果。若Promise
处理异常rejected
,await
表达式会把Promise
的异常原因抛出。另外,如果await
操作符后的表达式的值不是一个Promise
,则返回该值本身。
实例
function promise(){
return new Promise(function(resolve,reject){
var rand = Math.random() * 2;
setTimeout(function(){
resolve(`solve ${rand}`);
},1000)
})
}
(async function asyncPromise(){
var result = await promise();
console.log(result);
})();
// 捕捉异常
function promise(){
return new Promise(function(resolve,reject){
throw new Error(`reject`);
})
}
(async function asyncPromise(){
var result = await promise();
console.log(result);
})().catch((e) => {
console.log(e);
});
// 非promise对象直接返回该值本身
function notPromise(){
return 1;
}
(async function asyncPromise(){
var result = await notPromise();
console.log(result);
})();
- Python接口自动化-8-测试报告
- http应用优化和加速说明-负载均衡
- linux负载均衡总结性说明(四层负载/七层负载)
- 从MapX到MapXtreme2004[6]-标点心得
- silverlight3中的"伪"3D
- 暴利驱动的疯狂游戏“外挂”:非法获利可达数百万;X-Agent 后门大升级,俄罗斯 APT28 间谍活动更为隐蔽
- Nginx+keepalived双机热备(主从模式)
- 即使不做程序员,也要学会像程序员一样去思考
- 这5项高科技 正在颠覆未来医疗
- xml的解析
- “微信身份证”来了!下月起全国推广!
- silverlight3的"伪"3D续--图片横向轮换
- 从MapX到MapXtreme2004[5]-自定义工具
- 米市的热潮来袭?三枚域名超六位数美金交易
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 离线安装PySCF程序(1.5及更高版本)
- Python Debug(调试)的终极指南
- Linux下做计算常用的别名alias推荐
- 离线安装支持Intel MKL的R-3.6
- Dalton使用——磷光及其相关过程
- 【赵渝强老师】Flink的Watermark机制(基于Flink 1.11.0实现)
- 在Windows CMD里“使用”常见Linux命令
- 什么是Python中的Dask,它如何帮助你进行数据分析?
- a[i] = i++ 到底对不对?
- 如何监视Python程序的内存使用情况
- df -h和du -sh看到的硬盘使用不相等?
- MyBatis 中的一级和二级缓存
- 使用Cython加速你的Python代码
- 使用Python从PDF文件中提取数据
- 用Docker快速实现SAPT能量分解分析