Web log


August 30, 2019#JavaScript

In short

Promises makes chaining asynchronous tasks a little prettier than its deeply nested callback counterpart. For example:


This chainability is argued to be more easily reasoned about. Promises also come with some guarantees:

  1. Callbacks won’t be called before completion of the current run of the event loop, which avoids race conditions.
  2. Callbacks added with then() even after the success/failure of async operation will be called.
  3. Multiple callbacks can be added with then(). They will be executed in order.
  4. Callbacks are called one time at most.


catch(failureCallback) is short for then(null, failureCallback).

Regarding guarantee #1, some clarification might be needed. The JavaScript event loop does not preemt “the current run” (i.e. the currently running function). This makes reasoning about our code easier, but it also means that for example mouse events can be delayed by a long-running function. When using callbacks, it’s harder to know what is actually running, because we have functions calling functions.

Learned from MDN

Written by Simon Wessel.