Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Войти

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

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

© 2026 YeaHub

Документы

Медиа

Назад
Вопрос про JavaScript: async, function, promise

Что возвращает async-функция?

Вопрос проверяет понимание того, как async/await работает поверх Promise.

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

Любая async-функция всегда возвращает Promise. Если функция возвращает обычное значение, оно автоматически оборачивается в Promise.resolve. Если внутри происходит throw, возвращается Promise.reject. await не меняет тип возвращаемого значения функции.

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

async/await — это синтаксический сахар над Promise.

Определение

Async-функция — функция, которая всегда возвращает Promise, независимо от того, что возвращается внутри.

Примеры возврата значения

async function getNumber() {
  return 5;
}

getNumber().then(console.log); // 5

Эквивалентно:

function getNumber() {
  return Promise.resolve(5);
}

Пример с ошибкой

async function fail() {
  throw new Error("Oops");
}

fail().catch(console.error);

Использование await

async function fetchData() {
  const data = await Promise.resolve("data");
  return data;
}

Важно понимать

  1. await приостанавливает выполнение функции, но не блокирует основной поток.

  2. Внешний код всегда работает с Promise.

Вывод

async-функция — это всегда Promise, а await лишь упрощает работу с асинхронным кодом, не меняя модель выполнения.

Уровень

  • Рейтинг:

    5

  • Сложность:

    4

Навыки

  • JavaScript

    JavaScript

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

#async

#function

#promise

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