AJAX и Fetch API

1. Asynchronous JavaScript and XML

AJAX — метод отправки или запроса данных с последующим обновлением интерфейса по этим данным, без необходимости перезагрузки страницы. За счет этого уменьшается время отклика и веб-страница становится более интерактивной.

Несмотря на то, что в названии технологии присутствует XML, использовать его вовсе не обязательно. Под AJAX подразумевают любое общение с сервером без перезагрузки страницы.

В пример можно привести подгрузку данных:

  • На веб-странице происходит событие (страница загружается, нажимается кнопка "Показать больше", отправляется форма и т. п.).

  • На клиенте, с помощью JavaScript, реакцией на это событие выполнятся функция для работы с сервером, где создается и отправляется HTTP-запрос.

  • Сервер получает и обрабатывает HTTP-запрос, отправляя обратно в ответе данные в JSON-формате.

  • На клиенте, с помощью JavaScript, ответ от сервера обрабатывается, считываются данные и обновляется интерфейс.

2. Fetch API

Fetch API — предоставляет интерфейс, набор методов и свойств для отправки, получения и обработки ресурсов от сервера.

Это XMLHttpRequest нового поколения. Он предоставляет улучшенный интерфейс для составления запросов к серверу и построен на обещаниях (promise).

fetch(url, options)
Copy
  • url — обязательный параметр - путь к данным которые вы хотите получить.

  • options — необязательный параметр - объект настроек запроса. Содержит служебную информацию: метод (по умолчанию GET), заголовки, тело и т. д.

  • Возвращает промис, который содержит ответ сервера.

fetch('https://jsonplaceholder.typicode.com/users')
  .then(response => {
    //response handling
  })
  .then(data => {
    // data handling
  })
  .catch(error => {
    // error handling
  });
Copy

2.1. Response

В первый then передается экземпляр класса Response, снабженный различными методами и свойствами. В нем содержится служебная информация о состоянии ответа сервера.

В зависимости от типа получаемого контента, используется различный метод парса.

  • Response.prototype.json() - используется, когда от бекенда ожидаются данные в JSON-формате.

  • Response.prototype.text() - используется, когда от бекенда ожидаются данные в простом текстовом формате, например .csv - формат хранения табличных данных в виде текстового файла.

  • Response.prototype.blob() - используется, когда от бекенда ожидаются данные, описывающие файл, например изображение, аудио или видео.

fetch('https://jsonplaceholder.typicode.com/users')
  .then(response => {
    return response.json();
  })
  .then(data => {
    // data handling
  })
  .catch(error => {
    // error handling
  });
Copy

2.2. Headers

Headers — позволяет выполнять различные действия в заголовках HTTP-запроса и ответа. Эти действия включают в себя извлечение, настройку, добавление и удаление заголовков (методы append, has, get, set, delete).

const headers = new Headers({
  'Content-Type': 'application/json',
  'X-Custom-Header': 'custom value',
});

headers.append('Content-Type', 'text/bash');
headers.append('X-Custom-Header', 'custom value');
headers.has('Content-Type'); // true
headers.get('Content-Type'); // "text/bash"
headers.set('Content-Type', 'application/json');
headers.delete('X-Custom-Header');
Copy

Для составления заголовков запроса можно использовать просто литерал объекта со свойствами. В таком случае методов заголовков не будет, что зачастую и не требуется.

const headers = {
  'Content-Type': 'application/json',
  'X-Custom-Header': 'custom value',
};
Copy

Запрос с использованием заголовков может выглядеть так.

fetch('https://jsonplaceholder.typicode.com/users', {
  method: 'GET',
  headers: {
    Accept: 'application/json',
  },
}).then(response => {});
Copy

2.3. Ошибка при работе с асинхронным кодом

Разберем распространенную ошибку начинающих разработчиков, попытку использовать данные вне метода then, используем для этого предыдущий пример.

Ссылка на пример в Codepen.io

3. Вкладка Network

На вкладке Network отображаются все выполняющиеся на странице HTTP-запросы. Выбрав XHR (можно фильтровать по типу запроса), останутся только запросы к бекенду, и после нажатия кнопки, через некоторое время, отобразится запрос. Выбрав его, можно посмотреть служебную информацию и тело ответа на вкладках Headers, Preview, Response и Timing.

Ссылка на пример в Codepen.io

Вкладка Network

4. Работа с публичным RESTful API

Каждый API уникален, их тысячи, невозможно заучить код для работы с одним сервисом и использовать его для общения с другим. С другой стороны, RESTful API построены по принципам REST-архитектуры, а это значит, что можно понять принцип и методы работы, после чего, все что нужно сделать — это ознакомиться с документацией того сервиса, который необходимо использовать.

Для примера был выбран API ПриватБанка. Из документации берем URL для запроса информации о текущем курсе обмена валют.

https://api.privatbank.ua/p24api/pubinfo?exchange&json&coursid=11
Copy

Состоит из:

  • https://api.privatbank.ua/p24api — endpoint, base URL, точка входа на API.

  • /pubinfo — ресурс, к которому мы обращаемся

  • ? — говорит о том, что дальше идут параметры запроса

  • & — используется для указания смыслового И, связывает параметры запроса

Параметры ответа из документации:

  • ccy - код валюты

  • base_ccy - код национальной валюты

  • buy - курс покупки

  • sale - курс продажи

Ссылка на пример в Codepen.io

Last updated