Skip to content

Latest commit

 

History

History
90 lines (66 loc) · 1.87 KB

chapter1.md

File metadata and controls

90 lines (66 loc) · 1.87 KB

Async code

Async code is code that isn't done immediately when being called.

setTimeout(() => {
  console.log('do stuff');
}, 3000 )

3s seconds in the future the timeout is done and do stuff is echoed to the screen. We can see that the anonymous function we provide is being triggered when time has passed. Now for another more revealing example:

doWork( () => {
  console.log('call me when done');
})
function doWork(cb){
   setTimeout( () => {
     cb();
   }, 3000)
}

Other example of callback code are events here demonstrated by a jQuery example

input.on('click', () => {
  
})

The gist of callbacks and async in general is that one or more methods are invoked sometime in the future, unknown when.

The Problem

So we established a callback can be a timer, ajax code or even an event but what is the problem with all that?

One word Readability

Imagine doing the following code

syncCode()  // emit 1
syncCode2()  // emit 2
asyncCode()  // emit 3
syncCode4()  // emit 4

The output could very well be

1,2,4,3

Because the async method may take a long time to finish. There is really no way of knowing by looking at it when something finish. The problem is if we care about order so that we get 1,2,3,4

We might resort to a callback making it look like

syncCode()
syncCode()2
asyncCode(()= > {
   syncCode4()
})

At this point it is readable, somewhat but imagine we have only async code then it might look like:

asyncCode(() => {
   asyncCode2(() => {
     asyncCode3() => {
     
     }
   })
})

Also known as callback hell, pause for effect :)

For that reason promises started to exist so we got code looking like

  getData()
    .then(getMoreData)
    .then(getEvenMoreData)

This is great for Request/Response patterns but for more advanced async scenarios I dare say only Rxjs fits the bill.