Many if not most promise-related headaches come from incorrectly ordered Promise.prototype.then()
and Promise.prototype.catch()
methods. The order in which these methods are chained to a promise can lead to very different behaviors. Let’s take a look at a very simple example:
代码实现
const myPromise = () => Promise.reject('Oops!');
const logger = data => console.log(data);
const identity = data => data;
myPromise().catch(identity).then(logger); // LOGS: Oops!
myPromise().then(logger).catch(identity); // Nothing is logged
As you can see from this example, swapping the catch()
and then()
methods results in entirely different behavior, even though the promise has the same result. This is due to the fact that each chained method will result itself in a promise. This means that the first one will pass its result to the second, the second to the third and so on and so forth. While this might seem obvious when looking at an example like this one, many times it’s overlooked and can result in hard to debug issues. This is especially true when the promise chain is long and complicated.
So, next time you are working with promises, try to think of then()
and catch()
methods in terms of promise chaining and remember that order matters!