<MyRusakov.ru />

Разработчик игр на Unreal Engine

Разработчик игр на Unreal Engine

Этот комплект с нуля всего за 7 месяцев сделает Вас Unreal-разработчиком. И при этом учиться достаточно 1 час в день.

Начнёте Вы с основ программирования, постепенно перейдя к C++. Затем очень подробно изучите Unreal Engine, и после научитесь программировать на C++ в Unreal Engine. В конце создадите крупный проект на C++ в Unreal Engine для своего портфолио.

Комплект содержит:

- 416 видеоуроков

- 95 часов видео

- 1024 задания для закрепления материала из уроков

- 3 финальных тестирования

- 4 сертификата

- 12 Бонусных курсов

Подробнее
Подписка

Подпишитесь на мой канал на YouTube, где я регулярно публикую новые видео.

YouTube Подписаться

Подписавшись по E-mail, Вы будете получать уведомления о новых статьях.

Подписка Подписаться

Добавляйтесь ко мне в друзья ВКонтакте! Отзывы о сайте и обо мне оставляйте в моей группе.

Мой аккаунт Мой аккаунт Моя группа
Опрос

Какая тема Вас интересует больше?

Fetch API: GET и POST запросы

Fetch API: GET и POST запросы

Итак продолжаем изучать Fetch API в JavaScript. Первую статью из цикла вы можете найти здесь.

Для загрузки JSON данных на страницу, а формат JSON, как вы знаете используется повсеместно в современном Интернете для обмена данными, мы можем выполнить следующий код:

fetch('https://api.github.com/users/fabpot')
  .then(res => res.json())
  .then(json => console.log(json));

Что здесь происходит? Здесь при выполнении HTTP запроса, возвращается промис с данными, который мы затем преобразуем в формат JSON с помощью метода json() объекта Response.

Однако, здесь не все так просто. Метод json() возвращает снова промиc, что означает, что нам нужно повторно вызвать метод then() для получения того самого JSON объекта.

Заголовки запроса

fetch('https://api.github.com/users/fabpot', {
  headers: new Headers({                     // устанавливаем заголовки
    'User-agent': 'Chrome/64.0 My Own Agent'
  })
})
.then(response => response.json())        // получаем ответ в виде промиса
.then(data => {
  console.log(data)                          // выводим данные в консоль
})
.catch(error => console.error(error))     // или ошибку, если что-то пошло не так

Возможность устанавливать заголовки запроса очень сильно расширает возможности использования Fetch API. Заголовки можно установить с помощью объекта Headers():

// создаем пустой объект Headers
let headers = new Headers();

// Добавим пару заголовков
headers.append('Content-Type', 'text/html');
headers.append('X-My-Own-Header', 'Myrusakov LLC.');

// Методы для проверки наличия, получения и установки заголовков
headers.has('Content-Type'); // true
headers.get('Content-Type'); // "text/html"
headers.set('Content-Type', 'application/json');

// Удаляем заголовок
headers.delete('X-My-Own-Header');

// Укороченный вариант
let headers = new Headers({
    'Content-Type': 'text/plain',
    'X-My-Own-Header': 'Myrusakov LLC.'
});

POST Запросы

А вот так можно отправить POST запрос:

post('https://appdividend.com/api/v1/users', {user: 'Krunal'})
  .then(data => console.log(data))      // обрабатываем результат вызова response.json()
  .catch(error => console.error(error))

function post(url, data) {
  return fetch(url, {
    credentials: 'same-origin',  // параметр определяющий передвать ли разные сессионные данные вместе с запросом
    method: 'POST',              // метод POST 
    body: JSON.stringify(data),  // типа запрашиаемого документа
    headers: new Headers({
      'Content-Type': 'application/json'
    }),
  })
  .then(response => response.json()) // возвращаем промис
}

Вот так можно работать с Fetch API, используя его вместо XMLHttpRequest и других.

Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (http://myrusakov.ru)!

Добавляйтесь ко мне в друзья ВКонтакте: http://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: http://vk.com/rusakovmy.

Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления

Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

Порекомендуйте эту статью друзьям:

Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

  1. Кнопка:

    Она выглядит вот так: Как создать свой сайт

  2. Текстовая ссылка:

    Она выглядит вот так: Как создать свой сайт

  3. BB-код ссылки для форумов (например, можете поставить её в подписи):

Комментарии (0):

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