- 28
- 0
问题描述
今天看到一个关于js执行顺序的问题,不太了解async awite中awite后的代码的执行时机
- 问题1. 为啥promise2、promise3输出比async1 end输出早?如果都是微任务的话,不是async1 end先加入微任务队列的吗?
- 问题2. 为什么async1 end又先于promise4输出呢?
相关代码
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')
}).then(function() {
console.log('promise3')
}).then(function() {
console.log('promise4')
}).then(function() {
console.log('promise5')
}).then(function() {
console.log('promise6')
}).then(function() {
console.log('promise7')
}).then(function() {
console.log('promise8')
})
console.log('script end')
chrome 70.0.3538.102 结果
script start
async1 start
async2
promise1
script end
promise2 // 与 chrome canary 73 不一致
promise3 // 与 chrome canary 73 不一致
async1 end // 与 chrome canary 73 不一致
promise4
promise5
promise6
promise7
promise8
setTimeout
Chrome canary 73.0.3646.0(同node8.12.0):
script start
async1 start
async2
promise1
script end
async1 end // 与 chrome 70 不一致
promise2 // 与 chrome 70 不一致
promise3 // 与 chrome 70 不一致
promise4
promise5
promise6
promise7
promise8
setTimeout - 共 0 条
- 全部回答
-
泪未流〃心先碎 普通会员 1楼
在JavaScript中,async/await和Promise是两种常用的异步编程技术。
- Promise:Promise是一种处理异步操作的构造函数。Promise有两种状态:pending(等待中)和fulfilled(已完成)。当一个Promise被await时,它会立即返回,然后将Promise的resolve或reject方法设置为相应的值。
示例: ```javascript let promise = new Promise((resolve, reject) => { setTimeout(() => { resolve('Hello World'); }, 1000); });
console.log(promise); // Output: Promise {then: function(), reject: function()} ```
- async/await:async/await是Promise的一个扩展,它允许我们使用同步代码块,来编写异步代码。await关键字用于等待异步操作完成,而async关键字则用于定义一个函数是异步的。
示例: ```javascript async function sayHello() { let message = 'Hello World'; await new Promise((resolve, reject) => { setTimeout(() => { resolve(message); }, 1000); }); }
sayHello(); // Output: Hello World ```
关于async/await的执行顺序,通常情况下,async函数的执行顺序是按照Promise的状态顺序,从fulfilled开始,然后是pending,最后是rejected。如果一个Promise有多个then方法,那么它们的执行顺序是按照then方法的顺序进行的。
但是,这种执行顺序可能会受到多种因素的影响,包括异步函数的执行顺序、回调函数的执行顺序、Promise的状态改变顺序等。在实际开发中,我们需要根据具体的情况来确定异步函数的执行顺序和回调函数的执行顺序。
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部
