About 1 to 2 hours
- 15 minutes for Lesson
- 30 minutes for Demonstration
- 50 minutes for Independent Practice
- 10 minutes for Checking Understanding
- Know how to create a JavaScript function, named and anonymous.
- Know what Asynchronous means.
- Callbacks are an important part of JavaScript's (and any asynchronous language's) history. You will learn about "callback hell" and how promises help you "reach heaven" again.
Apprentices will be able to:
- Identify and write callbacks and promises.
- Know when to use a promise.
- callback
new Promise(((resolve, reject) => {}))
promise.then()
Promise.all()
- async / await
- done()
- Video on Callbacks, Promises, Async-Await (25min watch)
- 2:31 - Callbacks
- 10:33 - Promises
- 19:58 - Async-Await
- Watch this video on Callbacks, Promises, Async Await. It's 24 minutes, but it's totally understandable at 2x speed.
- A callback is just a function that is called when another function is done.
- We have them because JavaScript is asynchronous.
- A promise is a class of object. Think of it as a literal promise. Like a task that you promise to finish later.
- It's built into most browsers (all but IE: Browser Support).
- It's different from the object return by jQuery's AJAX but similar.
- It's the object returned by
fetch
(like AJAX but built into most browsers)
- Open up dev console in browser.
- Write a function name counter and pass in another function(the callback) named cb as parameter.
function counter(cb) {
console.log('inside counter function ');
cb(); //here callback function gets called by counter()
}
counter(function(){
console.log('inside callback function');
});
- If we again call counter() inside cb() definition then we can see a pattern of deep nesting, known as callback hell.
function counter(cb){
console.log('inside counter function ');
cb();
}
counter(function(){
console.log('inside callback function');
counter(function(){
console.log('inside callback function');
});
});
There's got to be an easier way to write things that depend on each other, right? Promises.
- Create a
Promise
and pass a callback to itsthen
method. Create callback that usessetTimeout
to mimic latency (network/database delay). The callback passed tosetTimeout
will resolve the promise (use the parameter). - Chain another
then
with a callback that console.logs something to show the flow of execution.
const isMomHappy = true;
// Promise
const willIGetNewPhone = new Promise(
(resolve, reject) => {
if (isMomHappy) {
const phone = {
brand: 'Samsung',
color: 'black'
};
resolve(phone);
} else {
const reason = new Error('mom is not happy');
reject(reason);}
}
);
const showOff = function (phone) {
const message = 'Hey friend, I have a new ' +
phone.color + ' ' + phone.brand + ' phone';
return Promise.resolve(message);
};
// call our promise
const askMom = function () {
willIGetNewPhone
.then(showOff)
.then(fulfilled => console.log(fulfilled))
.catch(error => console.log(error.message));
};
askMom();
- Play around in your favorite browser's dev console.
- Create several promises, each with callbacks with different
setTimeout
times. - Then call them in parallel, which promise method can you use for that?
- Chain a
catch
method (like how you did withthen
) to this promise, and pass another callback. Which promise parameter can you use to pass control fromthen
tocatch
? - Look at the object returned by creating a promise. What properties does it have? Look for its
status
. - Check its
status
again, has it changed?
- Why do we use callbacks?
- Define a promise in your own words.