async函数返回一个Promise对象,可以使用then方法添加回调函数。当函数执行的时候,一旦遇到await就会先返回,等到异步操作完成,再接着执行函数体内后面的语句。
看代码:
指定多少毫秒后输出一个值
function timeout(ms) { return new Promise((resolve) => { setTimeout(resolve, ms); }); } async function asyncPrint(value, ms) { await timeout(ms); console.log(value); } asyncPrint(‘hello world‘, 50);
async
函数内部return
语句返回的值,会成为then
方法回调函数的参数。
自己试着写了一段代码:
function f1(){ console.log(‘first step‘); return 1; } function f2(num){ return new Promise((resolve,reject)=>{ setTimeout(()=>{ resolve(2*num) },3000); }) } function f3(){ console.log(‘third step‘) } async function test(){ let first=await f1(); let second=await f2(first); console.log(second); let third=await f3(); console.log(‘end‘); }
输出结果如下:
正常情况下,await
命令后面是一个 Promise 对象,返回该对象的结果。如果不是 Promise 对象,就直接返回对应的值。
原文地址:https://www.cnblogs.com/shenting/p/10572857.html
时间: 2024-11-10 03:55:47