JavaScript метод Promise.catch()

JavaScript Promise

Определение и применение

JavaScript метод .catch()ECMAScript 2015 объекта Promise добавляет обработчик или обработчики, которые будут вызваны при изменении состояния объекта Promise на rejected (выполнение отклонено).

Метод .catch()ECMAScript 2015 ведет себя аналогично вызову метода then()ECMAScript 2015 с аргументами (undefined, onRejected), он реализован таким образом, что внутренне вызывает метод then()ECMAScript 2015 с этими аргументами (является сокращенным вариантом метода - алиасом).

Обращаю Ваше внимание на то, что обещание, возвращаемое методом .catch()ECMAScript 2015 отклоняется, если функция обработчик выдает ошибку, или возвращает обещание, которое само по себе отвергается, в противном случае оно разрешается.

Поддержка браузерами

МетодChrome
Chrome
Firefox
Firefox
Opera
Opera
Safari
Safari
Internet Explorer
IExplorer
Microsoft Edge
Edge
.catch()ECMAScript 201532.029.019.08.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()ECMAScript 2015 (обещание было успешно выполнено с заданным значением). С использованием методов then()ECMAScript 2015 мы добавили цепочку вызовов.

Обратите внимание, что внутри первого вызова метода then()ECMAScript 2015 мы генерируем исключение с определенном текстом ошибки. Что приводит к тому, что мы возвращаем объект Promise выполнение которого было отклонено. В результате следующий вызов метода then()ECMAScript 2015 будет обрабатывать ошибку, то есть сработает функция, которая предназначена для случая, когда обещание отклонено (второй аргумент).

На практике, как правило, для удобства и лучшей читаемости кода при обработке ошибок используют метод catch()ECMAScript 2015, а не используют синтаксис метода then()ECMAScript 2015 с двумя аргументами. Рассмотрим следующий пример:

const promise = Promise.resolve(); // обещание успешно выполнено с заданным значением

promise.then(() => {throw new Error("Ошибочка вышла")}) // генерируем исключение и возвращаем отклоненное обещание
              .catch(error => console.log(error.message)) // добавляем обработчик для отклоненного обещания
              .then(() => console.log("Обработчик будет вызван" )); // обработчик для успешного выполнения
  
// Ошибочка вышла
// Обработчик будет вызван

В этом примере мы инициализировали переменную, которая содержит объект Promise, который мы вернули с использованием метода resolve()ECMAScript 2015 (обещание было успешно выполнено).

С использованием метода then()ECMAScript 2015 мы добавили обработчик, вызываемый когда объект Promise имеет состояние fulfilled (успешное выполнение). Внутри него мы генерируем исключение с определенным текстом ошибки, что приводит к тому, что мы возвращаем объект Promise выполнение которого было отклонено.

Обратите внимание, что далее для обработки ошибки мы используем метод catch()ECMAScript 2015, а не используем синтаксис метода then()ECMAScript 2015 с двумя аргументами. Метод catch()ECMAScript 2015 является сокращенным вариантом метода then(undefined, onRejected).

Обратите внимание, что не смотря на то что мы обработали отклоненное обещание внутри метода catch()ECMAScript 2015, следующий за ним метод then()ECMAScript 2015 будет срабатывать как для обещания, которое было успешно выполнено (сработает функция из первого аргумента), так как функция обработчик метода catch()ECMAScript 2015 не выдает ошибку, или возвращает обещание, которое само по себе отвергается.

В следующем примере мы рассмотрим ситуацию в которой метод catch()ECMAScript 2015 будет генерировать исключение:

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()ECMAScript 2015 (обещание было отклонено).

Для обработки ошибок мы используем цепочку вызовов, которую мы составили с использованием метода catch()ECMAScript 2015. Обратите внимание, что первые два вызова метода catch()ECMAScript 2015 помимо того, что выводят в консоль текст ошибки, дополнительно еще генерируют исключение.

Третий метод catch()ECMAScript 2015 просто выводит в консоль текст ошибки и возвращает обещание, которое имеет состояние fulfilled (успешное выполнение), которое мы и обрабатываем в методе then()ECMAScript 2015, который находится в конце цепочки.

JavaScript Promise
×

Кажется, вы используете блокировщик рекламы :(

Этот ресурс не является коммерческим проектом и развивается на энтузиазме автора сайта, который посвящает все свое свободное время этому проекту.

Добавьте, пожалуйста, basicweb.ru в исключения блокировщика рекламы, этим вы поможете развитию проекта.