Javascript 使用 async 声明符和 await 操作符进行异步操作

  • async function 声明用于定义一个返回 AsyncFunction 对象的异步函数
  • await  操作符用于等待一个Promise 对象。它只能在异步函数 async function 中使用

语法:

[return_value] = await expression;

* 属于ES7语法,目前不被浏览器支持

使用注意:

1. await 必须在 async 声明的函数体中才能使用

2. await 后面只能是Promise对象,如果等待的不是 Promise 对象,则返回该值本身

3. await 等待Promise对象必须 resolve,否则函数体将不会继续执行

4. async 仅仅影响当前函数体

示例:

异步获取用户信息

function getUserInfo(){
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve('user information ...')
},3000);
})
} async function init(){
console.log('start of init')
var info = await getUserInfo()
console.log(info)
console.log('end of init')
} init()
console.log('end of script')

执行结果:

Javascript 使用 async 声明符和 await 操作符进行异步操作

执行async声明函数时,如果函数体内有await操作符的异步函数时:

1. 整个脚本会跳过异步操作继续执行后面的代码

2. async函数体内 await操作符后续的代码会等待 await标记的异步操作完成再执行

上一篇:.Net EF6+Mysql 环境搭建


下一篇:python写注册