ES7: Generator + promise async + await

Developer.mozilla.org/zh-CN/docs/…

Async: Function modifiers control functions to return promise instances

3. If an error occurs during the internal execution of the function, the failed PROMISE instance is returned, and the value is the reason for the failure

4, oneself return a promise, with oneself return mainly

5. If an exception is caught inside the function, it is still successful

6. The main purpose of using async is to use await inside functions

7, await: an instance of promise should be placed after “we are not writing and the browser will change it into a promise instance”, and the code below shall execute “await expression will suspend the whole async function execution process and give it control” in the body of await interrupt function. The code will not be executed until the promise instance behind await is successful. If the promise instance behind await fails, the code will not be executed.

8. Await is an asynchronous microtask: the body of a function encounters await, and the following code pauses “treat them as a task and place them in the microtask queue of the EventQueue”

async function func() {
    // await 1; //-> await Promise.resolve(1);

    let result1 = await api(1000);
    console.log(result1);

    let result2 = await api(3000);
    console.log(result2);
}
func(); 
Copy the code

9, Exercise 1

var resolveAfter2Seconds = function resolveAfter2Seconds() { console.log("starting slow promise"); return new Promise(resolve => { setTimeout(function () { resolve("slow"); console.log("slow promise is done"); }, 2000); }); }; var resolveAfter1Second = function resolveAfter1Second() { console.log("starting fast promise"); return new Promise(resolve => { setTimeout(function () { resolve("fast"); console.log("fast promise is done"); }, 1000); }); }; // sequential: /[sɪ t ɪ t ʃ ə l]/ var sequential = async function sequential() {console.log('== sequential START=='); // sequential: /[sɪ t ʃ ə l]/ var sequential = async function sequential() {console.log('== sequential START=='); const slow = await resolveAfter2Seconds(); console.log(slow); const fast = await resolveAfter1Second(); console.log(fast); };Copy the code

10, promise. All

var resolveAfter2Seconds = function resolveAfter2Seconds() {
    console.log("starting slow promise");
    return new Promise(resolve => {
        setTimeout(function () {
            resolve("slow");
            console.log("slow promise is done");
        }, 2000);
    });
};

var resolveAfter1Second = function resolveAfter1Second() {
    console.log("starting fast promise");
    return new Promise(resolve => {
        setTimeout(function () {
            resolve("fast");
            console.log("fast promise is done");
        }, 1000);
    });
};

var concurrentPromise = function concurrentPromise() {
    console.log('==CONCURRENT START with Promise.all==');
    return Promise.all([resolveAfter2Seconds(), resolveAfter1Second()])
        .then((messages) => {
            console.log(messages[0]);
            console.log(messages[1]);
        });
};
Copy the code

Log (‘==CONCURRENT START with promise.all ==’);

(2) First, promise. All is printed in the for loop, so it must be printed in order first:

console.log(“starting slow promise”); console.log(“starting fast promise”);

Log (“fast promise is done”); resolveAfter1Second (“fast promise is done”);

Then the asynchronous macro task, resolveAfter2Seconds, outputs console.log(“slow promise is done”);

(4) Finally, output slow and fast in the order of the passed array

11. Parallel output

var resolveAfter2Seconds = function resolveAfter2Seconds() {
    console.log("starting slow promise");
    return new Promise(resolve => {
        setTimeout(function () {
            resolve("slow");
            console.log("slow promise is done");
        }, 2000);
    });
};

var resolveAfter1Second = function resolveAfter1Second() {
    console.log("starting fast promise");
    return new Promise(resolve => {
        setTimeout(function () {
            resolve("fast");
            console.log("fast promise is done");
        }, 1000);
    });
};


var concurrent = async function concurrent() {
    console.log('==CONCURRENT START with await==');
    const slow = resolveAfter2Seconds();
    const fast = resolveAfter1Second();
    console.log(await slow);
    console.log(await fast);
};
Copy the code

Analysis:

Console. log(‘==CONCURRENT START with await==’);

(2) console.log(“starting slow promise”); console.log(“starting fast promise”);

(3) Both asynchronous macro tasks are stored; Console. log(” Fast promise is done”); Then the success state of the second promise becomes a success; Then when the first macro task is out of time, output console.log(“slow promise is done”); Then turn macro task 1 into success; This prints slow, and then fast

12,

var resolveAfter2Seconds = function resolveAfter2Seconds() { console.log("starting slow promise"); return new Promise(resolve => { setTimeout(function () { resolve("slow"); console.log("slow promise is done"); }, 2000); }); }; var resolveAfter1Second = function resolveAfter1Second() { console.log("starting fast promise"); return new Promise(resolve => { setTimeout(function () { resolve("fast"); console.log("fast promise is done"); }, 1000); }); }; Parallel = async function parallel() {console.log('== parallel with await ') {// parallel: parallel /[ˈpærəl]/ var parallel = async function parallel() {console.log('== parallel with await ' Promise.all=='); await Promise.all([ (async () => { let result = await resolveAfter2Seconds(); console.log(result); })(), (async () => { let result = await resolveAfter1Second(); console.log(result); })(), ]); };Copy the code

13,

var resolveAfter2Seconds = function resolveAfter2Seconds() {
    console.log("starting slow promise");
    return new Promise(resolve => {
        setTimeout(function () {
            resolve("slow");
            console.log("slow promise is done");
        }, 2000);
    });
};

var resolveAfter1Second = function resolveAfter1Second() {
    console.log("starting fast promise");
    return new Promise(resolve => {
        setTimeout(function () {
            resolve("fast");
            console.log("fast promise is done");
        }, 1000);
    });
};

var parallelPromise = function parallelPromise() {
  console.log('==PARALLEL with Promise.then==');
  resolveAfter2Seconds().then((message) => console.log(message));
  resolveAfter1Second().then((message) => console.log(message));
};
Copy the code