'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