Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

Документы

Медиа

Назад
Вопрос про JavaScript: promise, error-handling

Как обработать ошибку в промисах без catch, используя только then?

Вопрос проверяет знание альтернативных способов обработки ошибок в промисах.

Короткий ответ

Второй аргумент then — это аналог catch:

promise.then(
  result => console.log(result),
  error => console.error(error) // Обработка ошибки
);

Длинный ответ

Сравнение с catch:

// Вариант 1: catch
promise
  .then(result => console.log(result))
  .catch(error => console.error(error));

// Вариант 2: then с двумя аргументами
promise.then(
  result => console.log(result),
  error => console.error(error)
);

Различие:

  • catch перехватывает ошибки из всех предыдущих then.

  • Второй аргумент then — только ошибки текущего промиса.

Вывод:
Оба способа работают, но catch обычно предпочтительнее для цепочки промисов.

Уровень

  • Рейтинг:

    3

  • Сложность:

    6

Навыки

  • JavaScript

    JavaScript

Ключевые слова

#promise

#error-handling

Подпишись на React Developer в телеграм