This is the 30th day of my participation in the August Challenge

Five, asynchronous programming practical problems

5.1 Pay attention to the then writing of Promise to obtain data (serial)

We need to implement a program that outputs each value with a delay of 1 second for a total of 5 seconds, starting with the Promise loop, which is relatively cumbersome:

const setDelay = (millisecond) = > {
  return new Promise((resolve, reject) = > {
    if (typeofmillisecond ! ='number') {
      reject(new Error('Parameter must be of type number'));
    }
    setTimeout(() = > {
      resolve('I'm late${millisecond}The output 'after milliseconds)
    }, millisecond)
  })
}
Copy the code

We want to do: “loop the Promise function with a one-second delay”. The desired result should be: output every second after I delayed 1000 milliseconds, through three loops. We take for granted the following chain notation:

arr = [setDelay(1000), setDelay(1000), setDelay(1000)]

arr[0].then(result= > {
  console.log(result);
  return arr[1];
}).then(result= > {
  console.log(result);
  return arr[2];
}).then(result= > {
  console.log(result);
})
Copy the code

Unfortunately, you find that the output is parallel!! That’s three values in one second! . So what’s going on? When you add setDelay(1000) directly to the array, it is already executed. Note your execution statement (1000).

So what are the consequences of this? Return arr[1] (resolve); return arr[1] (resolve); So you can see that the program is parallel, it’s not called sequentially.

So what’s the solution? We do this by storing the function directly by its name (without implementing a Promise) :

arr = [setDelay, setDelay, setDelay];

arr[0] (1000).then(result= >{
  console.log(result);
  return arr[1] (1000);
}).then(result= >{
  console.log(result);
  return arr[2] (1000);
}).then(result= >{
  console.log(result);
})
Copy the code

This is the equivalent of storing promises in an array up front and executing them when you need to call them. Of course, you can also store it as a closure and execute it when you need to.

5.2 Promise Loop Gets data (serial) for loop

const p = arr.reduce((total, current) = > {
  return total.then((result) = > {
    console.log(result);
    return current()
  })
}, Promise.resolve('Program started'))
p.then((result) = > {
  console.log('It's over', result);
})
Copy the code

5.3 Async /await loop For loop to get data (serial)

(async () => {
  arr = [timeout(2000), timeout(1000), timeout(1000)]
  for (var i = 0; i < arr.length; i++) {
    result = await arr[i]();
    console.log(result);
  }
})()
Copy the code

Related articles

  • Asynchronous Promises and Async/Await are probably the most complete walkthroughs to get started
  • Detail the advantages of async/await over Promise
  • How to return the value from promise. then directly