Учебник по JS

ГЛАВНАЯ JS Введение JS Куда Вывод JS Заявления JS JS-синтаксис JS-комментарии JS-переменные JS Пусть Константа JS JS-операторы JS-арифметика Назначение JS JS-типы данных JS-функции JS-объекты JS-события JS-строки Строковые методы JS Поиск строки JS Шаблоны строк JS JS-номера Методы номеров JS JS-массивы Методы массива JS Сортировка массива JS Итерация массива JS Константа массива JS JS-даты Форматы даты JS Методы получения даты JS Методы установки даты JS JS-математика JS Случайный JS Булевы значения Сравнение JS JS-условия JS-переключатель JS цикл для Цикл JS для входа Цикл JS для Цикл JS во время Перерыв JS JS-итерации JS-наборы JS-карты JS Typeof Преобразование типов JS JS побитовый JS регулярное выражение JS-ошибки Область JS JS-подъем Строгий режим JS JS это ключевое слово Функция стрелки JS JS-классы JS JSON JS-отладка Руководство по стилю JS Лучшие практики JS JS-ошибки JS-производительность Зарезервированные слова JS

JS-версии

JS-версии JS 2009 (ES5) JS 2015 (ES6) JS 2016 JS 2017 JS 2018 JS IE/пограничный История JS

JS-объекты

Определения объектов Свойства объекта Методы объекта Отображение объекта Средства доступа к объектам Конструкторы объектов Прототипы объектов Итерации объектов Наборы объектов Карты объектов Ссылка на объект

JS-функции

Определения функций Параметры функции Вызов функции Вызов функции Функция Применить Закрытие функций

JS-классы

Введение в класс Наследование классов Статический класс

JS асинхронный

Обратные вызовы JS JS асинхронный JS-обещания JS асинхронный/ожидание

JS HTML DOM

Дом Введение DOM-методы Документ DOM DOM-элементы DOM HTML DOM-формы ДОМ CSS DOM-анимации События ДОМ Слушатель событий DOM DOM-навигация DOM-узлы Коллекции DOM Списки узлов DOM

Спецификация браузера JS

JS-окно JS-экран Местоположение JS История JS JS-навигатор Всплывающее оповещение JS JS Тайминг JS-куки

JS-веб-API

Введение в веб-API API веб-форм API истории веб-поиска API веб-хранилища API веб-работника API веб-выборки API веб-геолокации

JS АЯКС

Введение в АЯКС AJAX XMLHttp АЯКС-запрос AJAX-ответ XML-файл AJAX АЯКС PHP АЯКС АСП База данных AJAX AJAX-приложения Примеры AJAX

JS JSON

Введение в JSON Синтаксис JSON JSON против XML Типы данных JSON Анализ JSON Строковая JSON JSON-объекты JSON-массивы JSON-сервер JSON PHP JSON HTML JSON JSONP

JS против JQuery

Селекторы jQuery JQuery HTML jQuery CSS JQuery DOM

JS-графика

JS-графика JS Холст JS сюжет JS Chart.js JS Google Диаграмма JS D3.js

JS-примеры

JS-примеры JS HTML DOM JS HTML-ввод HTML-объекты JS HTML-события JS JS-браузер JS-редактор JS-упражнения JS-викторина JS-сертификат

JS-ссылки

Объекты JavaScript HTML DOM-объекты


AJAX — XMLHttpRequest


Объект XMLHttpRequest используется для запроса данных с сервера.


Отправить запрос на сервер

Чтобы отправить запрос на сервер, мы используем методы open() и send() XMLHttpRequestобъекта:

xhttp.open("GET", "ajax_info.txt", true);
xhttp.send();
Method Description
open(method, url, async) Specifies the type of request

method: the type of request: GET or POST
url: the server (file) location
async: true (asynchronous) or false (synchronous)
send() Sends the request to the server (used for GET)
send(string) Sends the request to the server (used for POST)

URL - файл на сервере

Параметр url open()метода — это адрес файла на сервере:

xhttp.open("GET", "ajax_test.asp", true);

Это может быть файл любого типа, например .txt и .xml, или файлы сценариев сервера, такие как .asp и .php (которые могут выполнять действия на сервере перед отправкой ответа обратно).


Асинхронность — правда или ложь?

Запросы к серверу должны отправляться асинхронно.

Параметр async метода open() должен быть установлен в true:

xhttp.open("GET", "ajax_test.asp", true);

Отправляя асинхронно, JavaScript не должен ждать ответа сервера, а вместо этого может:

  • выполнять другие скрипты, ожидая ответа сервера
  • обрабатывать ответ после того, как ответ будет готов

Значение по умолчанию для параметра async — async = true.

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

Синхронный XMLHttpRequest (async = false) не рекомендуется, поскольку выполнение JavaScript прекратится до тех пор, пока не будет готов ответ сервера. Если сервер занят или работает медленно, приложение зависнет или остановится.


ПОЛУЧИТЬ или ПОСТАВИТЬ?

GETпроще и быстрее, чем POST, и может использоваться в большинстве случаев.

Однако всегда используйте POST-запросы, когда:

  • Кэшированный файл не вариант (обновите файл или базу данных на сервере).
  • Отправка большого количества данных на сервер (POST не имеет ограничений по размеру).
  • При отправке пользовательского ввода (который может содержать неизвестные символы) POST более надежен и безопасен, чем GET.

ПОЛУЧИТЬ запросы

Простой GETзапрос:

Пример

xhttp.open("GET", "demo_get.asp");
xhttp.send();

В приведенном выше примере вы можете получить кешированный результат. Чтобы этого избежать, добавьте к URL уникальный идентификатор:

Пример

xhttp.open("GET", "demo_get.asp?t=" + Math.random());
xhttp.send();

Если вы хотите отправить информацию с помощью GETметода, добавьте информацию в URL-адрес:

Пример

xhttp.open("GET", "demo_get2.asp?fname=Henry&lname=Ford");
xhttp.send();

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



POST-запросы

Простой POSTзапрос:

Пример

xhttp.open("POST", "demo_post.asp");
xhttp.send();

Чтобы отправить данные, такие как HTML-форма, добавьте заголовок HTTP с расширением setRequestHeader(). Укажите данные, которые вы хотите отправить в send()методе:

Пример

xhttp.open("POST", "ajax_test.asp");
xhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xhttp.send("fname=Henry&lname=Ford");
Method Description
setRequestHeader(header, value) Adds HTTP headers to the request

header: specifies the header name
value: specifies the header value

Синхронный запрос

Чтобы выполнить синхронный запрос, измените третий параметр в open()методе на false:

xhttp.open("GET", "ajax_info.txt", false);

Иногда для быстрого тестирования используется async = false. Вы также найдете синхронные запросы в старом коде JavaScript.

Поскольку код будет ждать завершения работы сервера, в функции нет необходимости onreadystatechange :

Пример

xhttp.open("GET", "ajax_info.txt", false);
xhttp.send();
document.getElementById("demo").innerHTML = xhttp.responseText;

Синхронный XMLHttpRequest (async = false) не рекомендуется, поскольку выполнение JavaScript прекратится до тех пор, пока не будет готов ответ сервера. Если сервер занят или работает медленно, приложение зависнет или остановится.

Рекомендуется, чтобы современные инструменты разработчика предупреждали об использовании синхронных запросов и могли вызвать исключение InvalidAccessError при его возникновении.