Quick test: what do these code snippets do?
const a = new Promise(function (a) {
a
})
const b = new Promise(function (b) {
b("success")
})
const c = new Promise(function (a, b) {
b("failure")
})
const d = Promise.resolve("success")
const e = Promise.reject("failure")
const f = new Promise(function (a, b) {
a("success")
b("failure")
})
const g = new Promise(function (a, b) {
b("failure")
a("success")
})
const h = new Promise(function (a, b) {
throw new Error()
})
const i = new Promise(function (a, b) {
a()
})
const j = new Promise(function (a, b) {
b()
})
const k = (number) => {
return new Promise(function (a, b) {
a(number * 2)
})
}
Check by opening the console in your browser and test with e.g.
x.then(console.log).catch(alert)
Some points that were consolidated for me after the exercise:
-
“Promise” is not the same as “promise”. What I need to reach for is the “Promise()” constructor: “promise” is just the conventional name assigned to the promise object.
-
Promise() can only be constructed with new. Attempting to call it without new throws a TypeError. — MDN
-
Promise() takes an executor as its paramater. The executor receives two functions as parameters: resolveFunc (1st parameter) and rejectFunc (2nd parameter).
Sources: