Как сделать вызов асинхронной функции js?

Аватар пользователя Кирилл Маркеев
Кирилл Маркеев
06 февраля 2023

Рассмотрим два варианта вызова асинхронной функции: с помощью ключевого слова then и с помощью конструкции async / await.

Создадим асинхронную функцию, которая имитирует загрузку списка товаров с сервера:

const products = [
  {id: '1', title: 'product1'},
  {id: '2', title: 'product2'},
  {id: '3', title: 'product3'},
  {id: '4', title: 'product4'},
  {id: '5', title: 'product5'},
];

const fetchProducts = () => {
  return new Promise((resolve, _reject) => {
    setTimeout(() => resolve(products), 500);
  });
};

Теперь вызовем нашу функцию.

  • С помощью ключевого слова then:
fetchProducts()
  .then((data) => console.log(data)); 
/* => [
  {id: '1', title: 'product1'},
  {id: '2', title: 'product2'},
  {id: '3', title: 'product3'},
  {id: '4', title: 'product4'},
  {id: '5', title: 'product5'}
]
*/
  • C помощью async / await:
const getProductsFromServer = async () => {
  const data = await fetchProducts();
  console.log(data);
};

getProductsFromServer(); 
/* => [
  {id: '1', title: 'product1'},
  {id: '2', title: 'product2'},
  {id: '3', title: 'product3'},
  {id: '4', title: 'product4'},
  {id: '5', title: 'product5'}
]
*/
0 0

Есть что добавить? Зарегистрируйтесь

или войдите в аккаунт

Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»

Курсы по программированию в Хекслете

Программирование

Веб-разработка

Разработка, верстка и деплой сайтов и веб-приложений, трудоустройство для разработчиков

Frontend-разработка

Разработка внешнего интерфейса сайтов и веб-приложений и верстка

Создание сайтов

Разработка сайтов и веб-приложений на JS, Python, Java, PHP и Ruby on Rails

Backend-разработка

Разработка серверной части сайтов и веб-приложений

Тестирование

Ручное тестирование и автоматизированное тестирование на JS, Python, Java и PHP

Аналитика данных

Сбор, анализ и интерпретация данных на Python

Интенсивные курсы

Интенсивное обучение для продолжающих

DevOps

Автоматизация настройки локального окружения и серверов, развертывания и деплоя

Математика для программистов

Обучение разделам математики, которые будут полезны при изучении программирования

JavaScript

Разработка сайтов и веб-приложений и автоматизированное тестирование на JS

Тест-драйв

Python

Веб-разработка, автоматическое тестирование и аналитика данных на Python

Java

Веб-разработка и автоматическое тестирование на Java

PHP

Веб-разработка и автоматическое тестирование на PHP

Ruby

Разработка сайтов и веб-приложений на Ruby on Rails

Go

Курсы по веб-разработке на языке Go

Верстка

HTML

Современная верстка с помощью HTML и CSS

SQL

Проектирование базы данных, выполнение SQL-запросов и изучение реляционных СУБД

Git

Система управления версиями Git, регулярные выражения и основы командой строки

Бесплатные курсы

Бесплатные курсы по тестированию, дата-аналитике, верстке, программированию на Python, Java, PHP и JavaScript.

Базы данных

Фреймворки