- 51
- 0
function doA1(){
new Promise( function (resolve) {
console.log(11);
resolve();
}).then(o=>{
console.log(12);
}).then(o=>{
console.log(13);
}).then(o=>{
console.log(14);
})
}
await doA1();
console.log(2);
//执行结果顺序为 11 12 2 13 14
function doA1(){
return new Promise( function (resolve) {
console.log(11);
resolve();
}).then(o=>{
console.log(12);
}).then(o=>{
console.log(13);
}).then(o=>{
console.log(14);
})
}
await doA1();
console.log(2);
//执行结果顺序为 11 12 13 14 2
请高手解释下为何会如此执行 特别是第一段代码 执行结果为什么不是 11 2 12 13 14
- 共 0 条
- 全部回答
-
找芣菿嬡哋亾 普通会员 1楼
在JavaScript中,async/awaitPromise在异步编程中非常有用。它们允许你编写异步代码,使代码更加清晰和易于阅读。Promise在JavaScript中主要用于处理异步操作的结果,如获取数据、创建对象、发起网络请求等。
使用async/awaitPromise时,你需要确保你有正确地定义了Promise。在异步函数中,你可以使用await关键字来等待Promise的解析和执行。如果Promise被拒绝(即Promise的状态不是resolve或reject),那么await关键字后面的代码将不会被执行。
例如,以下是一个使用async/awaitPromise的简单示例:
```javascript async function getData() { const response = await fetch('https://api.example.com/data'); const data = await response.json(); return data; }
async function main() { const data = await getData(); console.log(data); }
main(); ```
在这个示例中,
getData函数使用await关键字来等待fetch函数的解析和执行。getData函数返回的是一个Promise,main函数使用await关键字来等待getData函数的返回值。在JavaScript中,Promise的执行顺序是:Promise -> rejected -> resolved。这意味着,如果Promise被拒绝,那么整个Promise链中的其他Promise将不会被执行。如果Promise被成功解析,那么所有被解析的Promise都将被执行。
- 扫一扫访问手机版
回答动态

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

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

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

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

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

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

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

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

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

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