'Promise inside of forEach in Typescript
I have the following code:
original_test(){
var arr=[1,2,3]
arr.forEach((a: any) => {
console.log("Before")
this.test().then(()=>{
console.log("After")
});
});
}
test(){
return new Promise((resolve) => {
resolve(true)
});
}
My problem is that I want my code to wait for the next iteration of forEach (until the promise completes). That means I want as console output:
"Before"
"After"
"Before"
"After"
"Before"
"After"
And what I get is:
"Before"
"Before"
"Before"
"After"
"After"
"After"
Many thanks!
Solution 1:[1]
I would do it like this:
async original_test() {
var arr=[1, 2, 3];
for(const item of arr) {
console.log("Before")
await this.test()
console.log("After")
}
};
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
Solution | Source |
---|---|
Solution 1 | sandrooco |