JavaScript метод Promise.catch()
JavaScript PromiseОпределение и применение
JavaScript метод .catch() объекта Promise добавляет обработчик или обработчики, которые будут вызваны при изменении состояния объекта Promise на rejected (выполнение отклонено).
Метод .catch() ведет себя аналогично вызову метода then() с аргументами (undefined, onRejected), он реализован таким образом, что внутренне вызывает метод then() с этими аргументами (является сокращенным вариантом метода - алиасом).
Обращаю Ваше внимание на то, что обещание, возвращаемое методом .catch() отклоняется, если функция обработчик выдает ошибку, или возвращает обещание, которое само по себе отвергается, в противном случае оно разрешается.
Поддержка браузерами
Метод | Chrome | Firefox | Opera | Safari | IExplorer | Edge |
---|---|---|---|---|---|---|
.catch() | 32.0 | 29.0 | 19.0 | 8.0 | Нет | Да |
JavaScript синтаксис:
p.catch(onRejected);
onRejected - Function
Спецификация
ECMAScript 2015 (6th Edition, ECMA-262)Значения параметров
Параметр | Описание |
---|---|
onRejected | Функция, которая будет вызвана, когда обещание отклонено. Эта функция имеет только один аргумент - значение с которым обещание было отклонено. Если это не функция, она внутренне заменяется функцией "Thrower" (она выдает ошибку, полученную в качестве аргумента). |
Пример использования
В следудующем примере мы с Вами рассмотрим ситуацию при которой в вызове обработчика, предназначенного для обработки состояния fulfilled (успешное выполнение) объекта Promise происходит ошибка:
const promise = Promise.resolve(); // обещание успешно выполнено с заданным значением promise.then(() => {throw new Error("Ошибочка вышла")}) // генерируем исключение и возвращаем отклоненное обещание .then( val => console.log( val ), // обработчик не будет вызван err => console.log( err.message )); // обработчик при отклоненном выполнении // Ошибочка вышла
В этом примере мы инициализировали переменную, которая содержит объект Promise, который мы вернули с использованием метода resolve() (обещание было успешно выполнено с заданным значением). С использованием методов then() мы добавили цепочку вызовов.
Обратите внимание, что внутри первого вызова метода then() мы генерируем исключение с определенном текстом ошибки. Что приводит к тому, что мы возвращаем объект Promise выполнение которого было отклонено. В результате следующий вызов метода then() будет обрабатывать ошибку, то есть сработает функция, которая предназначена для случая, когда обещание отклонено (второй аргумент).
На практике, как правило, для удобства и лучшей читаемости кода при обработке ошибок используют метод catch(), а не используют синтаксис метода then() с двумя аргументами. Рассмотрим следующий пример:
const promise = Promise.resolve(); // обещание успешно выполнено с заданным значением promise.then(() => {throw new Error("Ошибочка вышла")}) // генерируем исключение и возвращаем отклоненное обещание .catch(error => console.log(error.message)) // добавляем обработчик для отклоненного обещания .then(() => console.log("Обработчик будет вызван" )); // обработчик для успешного выполнения // Ошибочка вышла // Обработчик будет вызван
В этом примере мы инициализировали переменную, которая содержит объект Promise, который мы вернули с использованием метода resolve() (обещание было успешно выполнено).
С использованием метода then() мы добавили обработчик, вызываемый когда объект Promise имеет состояние fulfilled (успешное выполнение). Внутри него мы генерируем исключение с определенным текстом ошибки, что приводит к тому, что мы возвращаем объект Promise выполнение которого было отклонено.
Обратите внимание, что далее для обработки ошибки мы используем метод catch(), а не используем синтаксис метода then() с двумя аргументами. Метод catch() является сокращенным вариантом метода then(undefined, onRejected).
Обратите внимание, что не смотря на то что мы обработали отклоненное обещание внутри метода catch(), следующий за ним метод then() будет срабатывать как для обещания, которое было успешно выполнено (сработает функция из первого аргумента), так как функция обработчик метода catch() не выдает ошибку, или возвращает обещание, которое само по себе отвергается.
В следующем примере мы рассмотрим ситуацию в которой метод catch() будет генерировать исключение:
const promise = Promise.reject(new Error("Ошибочка")); // обещание отклонено promise.catch(error => { // добавляем обработчик для отклоненного обещания console.log(error.message); // выводит в консоль текст ошибки throw new Error("Ошибочка 2"); // генерируем исключение и возвращаем отклоненное обещание }).catch(error => { // добавляем обработчик для отклоненного обещания console.log(error.message); // выводит в консоль текст ошибки throw new Error("Ошибочка 3");// генерируем исключение и возвращаем отклоненное обещание }).catch(error => console.log(error.message)) // добавляем обработчик для отклоненного обещания и выводим в консоль текст ошибки .then(() => console.log("Наконец без ошибок" )); // обработчик для успешного выполнения // Ошибочка // Ошибочка 2 // Ошибочка 3 // Наконец без ошибок
В этом примере мы инициализировали переменную, которая содержит объект Promise, который мы вернули с использованием метода reject() (обещание было отклонено).
Для обработки ошибок мы используем цепочку вызовов, которую мы составили с использованием метода catch(). Обратите внимание, что первые два вызова метода catch() помимо того, что выводят в консоль текст ошибки, дополнительно еще генерируют исключение.
Третий метод catch() просто выводит в консоль текст ошибки и возвращает обещание, которое имеет состояние fulfilled (успешное выполнение), которое мы и обрабатываем в методе then(), который находится в конце цепочки.
JavaScript Promise