题1:
async function async1(){
console.log('async1 start');
await async2();
console.log('async1 end')
}
async function async2(){
console.log('async2')
}
console.log('script start');
setTimeout(function(){
console.log('setTimeout')
},0);
async1();
new Promise(function(resolve){
console.log('promise1');
resolve();
}).then(function(){
console.log('promise2')
});
console.log('script end')
题1运行结果:
script start
async1 start
async2
promise1
script end
async1 end
promise2
setTimeout
题2:
async function async1(){
console.log('async1 start');
await async2();
console.log('async1 end')
}
async function async2(){
console.log('async2')
}
async function async3(){
return Promise.resolve().then(()=> console.log('async 3'));
}
console.log('script start');
setTimeout(async function(){
console.log('setTimeout')
await async3();
console.log('async3 after')
},0);
async1();
new Promise(function(resolve){
console.log('promise1');
setTimeout(function(){
resolve();
},0);
}).then(function(){
console.log('promise2')
});
console.log('script end')
题2运行结果:
script start
async1 start
async2
promise1
script end
async1 end
setTimeout
async 3
async3 after
promise2