function resolveAfter2Seconds(x) {
return new Promise(resolve => {
setTimeout(() => {
resolve(x);
}, 2000);
});
}
async function f1() {
var x = await resolveAfter2Seconds(10);
console.log(x);
}
f1();
let x = 3;
Why do we see the following scenario?
- Entering the f1. Stops on await.
- Returns from f1 (console.log(x) command doesn't execute)
- assign 3 to x (ERROR! await skipped, js steps forward)
- Return to f1 on line "console.log(x)". Print x.
Why JS not waiting on await and steps forward? May you give me an advice?
function resolveAfter2Seconds(x) {
return new Promise(resolve => {
setTimeout(() => {
resolve(x);
}, 2000);
});
}
async function f1() {
var x = await resolveAfter2Seconds(10);
console.log(x);
}
f1();
let x = 3;
Why do we see the following scenario?
- Entering the f1. Stops on await.
- Returns from f1 (console.log(x) command doesn't execute)
- assign 3 to x (ERROR! await skipped, js steps forward)
- Return to f1 on line "console.log(x)". Print x.
Why JS not waiting on await and steps forward? May you give me an advice?
Share Improve this question asked May 2, 2019 at 20:47 Daniil VorobeyvDaniil Vorobeyv 1652 gold badges2 silver badges11 bronze badges 2 |2 Answers
Reset to default 12f1
is asynchronous (the await only occurs within that asynchronous context). Therefore, f1()
is executed, and because it's async, the let x = 3;
line executes immediately without waiting.
If you also await
the call to f1()
, it should do what you're expecting. However in order to use await
, you must wrap that code inside another async
function, and then execute that function.
Demo (no await):
function resolveAfter2Seconds(x) {
return new Promise(resolve => {
setTimeout(() => {
resolve(x);
}, 2000);
});
}
async function f1() {
var x = await resolveAfter2Seconds(10);
console.log(x);
}
f1();
let x = 3;
console.log(x);
Working version (with extra await):
function resolveAfter2Seconds(x) {
return new Promise(resolve => {
setTimeout(() => {
resolve(x);
}, 2000);
});
}
async function f1() {
var x = await resolveAfter2Seconds(10);
console.log(x);
}
async function f2() {
await f1();
let x = 3;
console.log(x);
};
f2();
You can't use await
outside an async
context...so at the end of the chain something has to be async. The bottom line is, anything you want to be waiting until after the f1()
executes must be either
- inside the
f2()
function after theawait
, or - executed within a
.then()
callback attached to the promise.
More simpler
(async function() {
function resolveAfter2Seconds(x) {
return new Promise(resolve => {
setTimeout(() => {
resolve(x);
}, 2000);
});
}
async function f1() {
var x = await resolveAfter2Seconds(10);
console.log(x);
}
await f1();
let x = 3;
console.log(x);
})();
await
your outer function call. – SLaks Commented May 2, 2019 at 20:48