Get to know MDN better
This page was translated from English by the community. Learn more and join the MDN Web Docs community.
This feature is well established and works across many devices and browser versions. It’s been available across browsers since июль 2015 г..
* Some parts of this feature may have varying levels of support.
Примечание: This feature is available in Web Workers, except for Service Workers.
XMLHttpRequest это API, который предоставляет клиенту функциональность для обмена данными между клиентом и сервером. Данный API предоставляет простой способ получения данных по ссылке без перезагрузки страницы. Это позволяет обновлять только часть веб-страницы не прерывая пользователя. XMLHttpRequest используется в AJAX запросах и особенно в single-page приложениях.
XMLHttpRequest изначально был разработан Microsoft и позже заимствован Mozilla, Apple, и Google. Сейчас он стандартизирован WHATWG. Несмотря на своё название, XMLHttpRequest может быть использован для получения любых типов данных, не только XML, и поддерживает протоколы помимо HTTP (включая file и ftp).
Чтобы начать работать с XMLHttpRequest, выполните этот код:
var myRequest = new XMLHttpRequest();более детальное описание создание объекта, можно увидеть в разделе Using XMLHttpRequest.
| void abort(); |
| DOMString getAllResponseHeaders(); |
| DOMString? getResponseHeader(DOMString header); |
| void open(DOMString method, DOMString url, optional boolean async, optional DOMString? user, optional DOMString? password); |
| void overrideMimeType(DOMString mime); |
| void send(); void send(ArrayBufferView data); void send(Blob data); void send(Document data); void send(DOMString? data); void send(FormData data); |
| void setRequestHeader(DOMString header, DOMString value); |
| Нестандартные методы |
| [noscript] void init(in nsIPrincipal principal, in nsIScriptContext scriptContext, in nsPIDOMWindow ownerWindow); |
| [noscript] void openRequest(in AUTF8String method, in AUTF8String url, in boolean async, in AString user, in AString password); |
| void sendAsBinary(in DOMString body); |
|
onreadystatechange |
Function? |
Callback - функция, которая вызывается всякий раз, когда поле readyState меняет своё значение. Callback выполняется в потоке работы приложения.
Внимание: Он не должен использоваться в синхронных
запросах, и не должен выполняться из нативного кода (? must not be
used from native code).
|
||||||||||||||||||||
| readyState | unsigned short |
Состояние запроса:
|
||||||||||||||||||||
| response | varies |
Тело сущности запроса. Согласно полю responseType, может быть ArrayBuffer, Blob, Document, JavaScript объектом (для "json"), или строкой. Равно null если запрос не завершён или окончен с ошибкой. |
||||||||||||||||||||
| responseText Только для чтения | DOMString | Ответ на запрос в виде строки или null в случае если запрос не успешен или ответ ещё не получен. | ||||||||||||||||||||
| responseType | XMLHttpRequestResponseType |
Может использоваться для определения типа ответа.
Note: Starting with Gecko 11.0
, as well as WebKit build 528,
these browsers no longer let you use the
responseType attribute when performing synchronous
requests. Attempting to do so throws an
NS_ERROR_DOM_INVALID_ACCESS_ERR exception. This change
has been proposed to the W3C for standardization.
|
||||||||||||||||||||
| responseXML Только для чтения | Document? |
Ответ является объектом DOM Document, или null в случае если запрос окончился ошибкой, или ответ не получен полностью, или если ответ невозможно распарсить как XML или HTML. Ответ парсится как если бы это был text/xml stream. Когда значение responseType равно "document" и запрос выполнен асинхронно, ответ парсится как text/html stream.
Примечание: Если сервер не работает с заголовком (не
присылает в ответе) "Content-type: text/xml", то можно
использовать метод
overrideMimeType() для того чтобы парсить получаемый ответ как XML.
|
||||||||||||||||||||
| status Только для чтения | unsigned short | Статус ответа на запрос. Равен кодам HTTP (200 - успешно, 404 не найдено, 301 - перенесено навсегда). | ||||||||||||||||||||
| statusText Только для чтения | DOMString | Строка статуса ответа. В отличи от поля status, эта строка включает в себя текст - ("200 OK", например). | ||||||||||||||||||||
| timeout | unsigned long |
Время в миллисекундах, после которого запрос будет отменён. Значение 0 (по умолчанию) значит что таймаута не будет. Никогда.
Примечание: Вы можете не использовать поле timeout
для синхронных запросов из owning window.
|
||||||||||||||||||||
| ontimeout | Function | Колбэк-функция которая будет вызвана в случае таймаута. |
||||||||||||||||||||
| upload | XMLHttpRequestUpload | Загрузка (upload process) может отслеживаться обработчиком события. | ||||||||||||||||||||
| withCredentials | boolean |
Определяет что cross-site запрос, согласно Access-Control должен использовать авторизацию (креды для логина и пароля) через куки, или заголовок с авторизационными данными. По умолчанию false.
Примечание: Не влияет на same-site запросы.
Примечание: Начиная с Gecko 11.0
, Gecko больше не позволяет
использовать поле withCredentials при выполнении
синхронных запросов. Попытка выполнить это выбрасывает
NS_ERROR_DOM_INVALID_ACCESS_ERR исключение.
|
| channel Только для чтения | nsIChannel | The channel used by the object when performing the request. This is null if the channel hasn't been created yet. In the case of a multi-part request, this is the initial channel, not the different parts in the multi-part request. Requires elevated privileges to access. |
| mozAnon Только для чтения | boolean |
Если значение равно true, запрос отправляется без куки и заголовков авторизации. |
| mozSystem Только для чтения | boolean |
Если значение равно true, same origin policy не будут использоваться в запросе (кроссдоменный запрос не сработает). |
| mozBackgroundRequest | boolean |
Этот метод не может быть вызван из контекста страницы. Для того чтобы воспользоваться им нужны повышенные привелегии (elevated privileges). Флаг, означающий что запрос от пользователя надо скрыть. Для пользователя не появится никаких сообщений и/или оповещений что запрос вообще был. В случае, если для продолжения запроса нужна какая-то аутентификация, и в других случаях было бы отображено оповещение, этот запрос просто не сработает.
Note: Этот флаг должен быть выставлен до вызова метода open().
|
| mozResponseArrayBuffer Только для чтения | ArrayBuffer | Массив, в который ляжет ответ от сервера, если ответ приходит в виде Javascript массива ([]). В случае, если запрос не удалось завершить, или если запрос не был отправлен, то это поле будет null. |
| multipart | boolean |
This Gecko-only feature was removed in Firefox/Gecko 22. Please use Server-Sent Events, Web Sockets, or responseText from progress events instead. Indicates whether or not the response is expected to be a stream of possibly multiple XML documents. If set to true, the content type of the initial response must be multipart/x-mixed-replace or an error will occur. All requests must be asynchronous. This enables support for server push; for each XML document that's written to this request, a new XML DOM document is created and the onload handler is called between documents.
Note: When this is set, the
onload handler and other event handlers are not reset
after the first XMLdocument is loaded, and the
onload handler is called after each part of the response
is received.
|
Конструктор создаёт объект XMLHttpRequest. Он должен быть вызван перед обращением к любому методу класса.
Gecko/Firefox 16 добавляет нестандартные параметры в конструктор, для лучшего взаимодействия с режимом инкогнито, (смотри Bug 692677). Установка флага mozAnon в значение true создаёт сущность AnonXMLHttpRequest() описанную в XMLHttpRequest спецификации, но не реализованную не в одном из браузеров (информация сентября 2012).
XMLHttpRequest ( JSObject objParameters ); Параметры (нестандартные) objParametersВы можете использовать два флага:
mozAnonBoolean: Использование этого флага уберёт из запроса заголовки origin, и user credentials. Кроме этого, куки не будут отправлены в запросе, если только они не будут добавлены к запросу специально, через метод setRequestHeader.
mozSystemBoolean: Если выставить этот флаг в значение true то это позволит делать cross-доменные запросы без необходимости получения специальных заголовков со стороны сервера (CORS). Для использования этого флага необходимо использовать дополнительный флаг* mozAnon: true, поскольку для отправки запроса на другой домен, нельзя использовать куки и креды пользователя. Этот флаг работает только с привилегированными (одобренными) приложениями; он не сработает с произвольно загруженными страницами.*
Отменяет запрос, если он был отправлен.
Возвращает все заголовки ответа как строку, или null если ответ не был получен. Для multypart запросов возвращает заголовки текущей части запроса, а не всего канала.
Возвращает значение указанного заголовка из полученного ответа, или null в случает если ответ не получен, или такого заголовка в ответе нет. Возвращаемая строка имеет кодировку UTF.
Примечание: Если в ответе есть заголовки с одни названием, то значения этих заголовков будут объеденены в одну строку, разделённую запятой и пробелом.
Инициализирует запрос. Этот метод может (и должен) быть вызван из JavaScript-кода; если необходимо вызвать запрос из нативного кода, то нужно использовать метод openRequest().
Примечание: Вызов этого метода из активного запроса (если метод open() или openRequest() уже были вызваны) эквивалентно вызову метода abort().
HTTP метод отправки сообщения - "GET", "POST", "PUT", "DELETE", и проч.. Ignored for non-HTTP(S) URLs.
urlURL адрес, на который будет отправлено сообщение.
asyncНеобязательный boolean параметр, по умолчанию равный true. Определяет, будет ли запрос отправлен асинхронно. Если значение равно false, метод send() вернёт ответ в общем потоке работы приложения (иначе говоря, приложение зависнет на некоторое время), в противном случае, ответ может быть получен только при помощи определённых обработчиков событий. В случае, если используется отправка multipart запроса, то этот атрибут должен быть true, или будет выброшено исключение.
Примечание: Начиная с Gecko 30.0, синхронные запросы объявлены как deprecated, в силу того что все пользователи недовольны тем, что приложение "зависает".
Необязательный параметр, используется для аутентификации пользователя. По умолчанию, пустая строка.
passwordНеобязательный параметр, используется для аутентификации пользователя. По умолчанию пустая строка.
Переопределяет MIME тип, получаемый от сервера. Это может быть использовано, например, для того чтобы получить и распарсить данные в формате text/xml, даже, если сервер сообщает что это не так. Этот метод должен быть вызван перед вызовом метода send().
void overrideMimeType(DOMString mimetype);Отправляет запрос. Если запрос асинхронный (а по умолчанию это так), этот метод вернёт значение сразу после того как метод вызван.
Примечание: В этом случае, в ответе не будет содержаться информации, которая пришла с сервера, поскольку она ещё не пришла. Для того чтобы получить эту информацию, нужно слушать события загрузки, или использовать promise.
Если запрос синхронный, то метод вернёт значение только после того, как придёт запрос от сервера.
Примечание: Все необходимые обработчики событий должны быть установлены перед вызовом send().
Примечание: Лучше не использовать параметр ArrayBuffer. Сейчас он не входит в спецификацию XMLHttpRequest. Вместо него можно использовать ArrayBufferView (смотри таблицу совместимости для различных версий).
Если тип data - Document, то он будет сериализован перед отправкой. Firefox до версии 3 всегда отправляет такой запрос в кодировке UTF-8; Firefox 3 отправляет данные в той кодировке, которая указаны в body.xmlEncoding, или UTF-8 если такой информации нет.
If it's an nsIInputStream, it must be compatible with nsIUploadChannel's setUploadStream() method. In that case, a Content-Length header is added to the request, with its value obtained using nsIInputStream's available() method. Any headers included at the top of the stream are treated as part of the message body. The stream's MIMEtype should be specified by setting the Content-Type header using the setRequestHeader() method prior to calling send().
The best way to send binary content (like in files upload) is using an ArrayBufferView or Blobs in conjuncton with the send() method. However, if you want to send a stringifiable raw data, use the sendAsBinary() method instead, or the StringView Non native typed arrays superclass.
Устанавливает значение заголовка HTTP-запроса. Вы должны вызвать setRequestHeader() после open(), но перед send(). Если данный метод вызывается несколько раз с одним и тем же заголовком, все значения объединяются в один заголовок запроса.
void setRequestHeader( DOMString header, DOMString value ); Параметры headerИмя заголовка, значение которого будет установлено.
valueЗначение, заданное как тело заголовка.
Инициализирует объект для использования с C++ кодом.
Предупреждение: Этот метод нельзя вызывать из JavaScript.
Принцип, используемый для запроса; не должен быть null.
scriptContextКонтекст скрипта, используемого для запроса; не должен быть null.
ownerWindowОкно, связанное с запросом; может быть null.
Инициализирует запрос. Этот метод должен использоваться из собственного кода; для инициализации запроса из кода JavaScript вместо этого используйте используйте open() метод. Смотрите документацию для open().
Вариант метода send() который посылает бинарные данные.
Примечание: Этот нестандартный метод считается устарелым по состоянию на Gecko 31, и со временем будет удалён. Взамен может использоваться стандарт метода send(Blob data).
Данный метод используется в сочетании с методом readAsBinaryString, который присутствует в FileReader API, и позволяет прочитать и загрузить файл любого типа и превратить необработанные данные в JSON-строку.
Параметры bodyТело запроса в виде DOMstring. Эти данные конвертированы в строку с однобайтовыми символами с помощью усечения (удаления байта с высоким порядком в каждом символе).
sendAsBinary() polyfillSince sendAsBinary() is an experimental feature, here is a polyfill for browsers that don't support the sendAsBinary() method but support typed arrays.
Примечание: It's possible to build this polyfill putting two types of data as argument for send(): an ArrayBuffer (ui8Data.buffer – the commented code) or an ArrayBufferView (ui8Data, which is a typed array of 8-bit unsigned integers – uncommented code). However, on Google Chrome, when you try to send an ArrayBuffer, the following warning message will appear: ArrayBuffer is deprecated in XMLHttpRequest.send(). Use ArrayBufferView instead. Another possible approach to send binary data is the StringView Non native typed arrays superclass in conjunction with the send() method.
onreadystatechange as a property of the XMLHttpRequest instance is supported in all browsers.
Since then, a number of additional event handlers were implemented in various browsers (onload, onerror, onprogress, etc.). These are supported in Firefox. In particular, see nsIXMLHttpRequestEventTarget and Using XMLHttpRequest.
More recent browsers, including Firefox, also support listening to the XMLHttpRequest events via standard addEventListener APIs in addition to setting on* properties to a handler function.
When using System XHR via the mozSystem property, for example for Firefox OS apps, you need to be sure to add the systemXHR permission into your manifest file. System XHR can be used in privileged or certified apps.
Enable JavaScript to view this browser compatibility table.
MDN articles about XMLHttpRequest:
XMLHttpRequest references from W3C and browser vendors:
Chrome scope availability - how to access from JSM modules etc which do not have access to DOM
This page was last modified on 29 апр. 2026 г. by MDN contributors.
Your blueprint for a better internet.
Visit Mozilla Corporation’s not-for-profit parent, the Mozilla Foundation.
Portions of this content are ©1998–2026 by individual mozilla.org contributors. Content available under a Creative Commons license.