ES2015: Promise, Async/Await
Date: 22 Feb 2023
• Promises are an alternative to callbacks for delivering the results of an asynchronous computation.
data:image/s3,"s3://crabby-images/c7902/c79020470774bb937d9f785fbabc39e573dcd3b6" alt=""
• A Promise is always in one of three mutually exclusive states: - Before the result is ready, the Promise is pending. - If a result is available, the Promise is fulfilled. - If an error happened, the Promise is rejected.
• A Promise is settled if “things are done” (if it is either fulfilled or rejected).
• A Promise is settled exactly once and then remains unchanged.
• Promise reactions are callbacks that you register with the Promise method then(), to be notified of fulfillment or a rejection.
• A thenable is an object that has a Promise-style then() method. Whenever the API is only interested in being notified of settlements, it only demands thenables (e.g. the values returned from then() and catch(); or the values handed to Promise.all() , Promise.allSettled(), Promise.race()), Promise.race()).
data:image/s3,"s3://crabby-images/af3dd/af3dd77b7aca7e28a405e1a0dfe95a149551bddf" alt=""
• Create a promise
data:image/s3,"s3://crabby-images/88fcc/88fcc2f42c10ee5336c67ce9622372d07dd8bb15" alt=""
• Consuming a Promise
data:image/s3,"s3://crabby-images/ff353/ff35390b61d728efd350e15623ea885077031bd1" alt=""
• Other ways of creating Promises - Promise.resolve() - Promise.reject()
• Chaining Promises
data:image/s3,"s3://crabby-images/84987/8498780836d0710d1e74354241fbb28bb65d4d80" alt=""
• Promise anti-pattern: nested
data:image/s3,"s3://crabby-images/70e48/70e48bd8e952888f2881ea55eb607909f78ea2b4" alt=""
• then always return a promise
• Async functions: always return a promise
• Await: works only inside async functions
• Can’t use await in regular functions
• await won’t work in the top-level code
• Error handling
data:image/s3,"s3://crabby-images/199f8/199f8d967bd7ffcce2f3a2c3373b628bf167e316" alt=""
• Too Sequential
data:image/s3,"s3://crabby-images/6aa35/6aa3537dbef51dd1a10da4f86fa94e7de7b986f1" alt=""
• http://speakingjs.com/es5/index.html
• http://exploringjs.com/es6/index.html
• http://exploringjs.com/es2016-es2017/ch_async-functions.html
• http://exploringjs.com/es2018-es2019/toc.html
• http://eloquentjavascript.net/
• https://github.com/getify/You-Dont-Know-JS#titles