--- title: XMLHttpRequest slug: Web/API/XMLHttpRequest tags: - AJAX - API - Communication - HTTP - Interface - Reference - Web - XHR - XMLHttpRequest translation_of: Web/API/XMLHttpRequest ---
{{DefaultAPISidebar("XMLHttpRequest")}}

XMLHttpRequest (XHR) オブジェクトは、サーバーと対話するために使用されます。ページ全体を更新する必要なしに、データを受け取ることができます。これでユーザーの作業を中断させることなく、ウェブページの一部を更新することができます。 XMLHttpRequest は {{Glossary("AJAX")}} プログラミングで頻繁に使用されます。

{{InheritanceDiagram(650, 150)}}

XMLHttpRequest という名前ではあるものの、 XML だけでなくあらゆる種類のデータを受け取るために使用することができます。

通信においてサーバーからのイベントデータやメッセージデータの受信を含む必要があるのであれば、 Server-sent event の {{domxref("EventSource")}} インターフェイスを使用することも検討してください。全二重の通信では、 WebSocket の方が良いかもしれません。

コンストラクター

{{domxref("XMLHttpRequest.XMLHttpRequest", "XMLHttpRequest()")}}
XMLHttpRequest を初期化するコンストラクターです。これは、他のメソッドを呼び出す前に呼び出さなければなりません。

プロパティ

このインターフェイスは、 {{domxref("XMLHttpRequestEventTarget")}} および {{domxref("EventTarget")}} のプロパティを継承します。

{{domxref("XMLHttpRequest.onreadystatechange")}}
{{domxref("EventHandler")}} で、これは readyState 属性が変化する度に呼び出されます。
{{domxref("XMLHttpRequest.readyState")}} {{readonlyinline}}
リクエストの状態を unsigned short で返します。
{{domxref("XMLHttpRequest.response")}} {{readonlyinline}}
リクエストのエンティティ本文を含む {{jsxref("ArrayBuffer")}}, {{domxref("Blob")}}, {{domxref("Document")}}, JavaScript オブジェクト, {{domxref("DOMString")}} の何れかを、 {{domxref("XMLHttpRequest.responseType")}} の値に応じて返します。
{{domxref("XMLHttpRequest.responseText")}} {{readonlyinline}}
リクエストに対するレスポンスがテキスト形式で入った {{domxref("DOMString")}} を返すか、リクエストが失敗した場合や、まだ送信されていない場合は null を返します。
{{domxref("XMLHttpRequest.responseType")}}
レスポンス型を定義する、列挙型の値です。
{{domxref("XMLHttpRequest.responseURL")}} {{readonlyinline}}
レスポンスのシリアライズされた URL、または URL が null であれば空文字列を返します。
{{domxref("XMLHttpRequest.responseXML")}} {{readonlyinline}}
リクエストに対するレスポンスが入った {{domxref("Document")}} を返すか、またはリクエストが成功しなかった場合、まだ送信されていない場合、 XML または HTML として解釈できなかった場合は null を返します。
{{domxref("XMLHttpRequest.status")}} {{readonlyinline}}
リクエストに対するレスポンスのステータスを unsigned short で返します。
{{domxref("XMLHttpRequest.statusText")}} {{readonlyinline}}
HTTP サーバーから返ってきたレスポンス文字列が入った {{domxref("DOMString")}} を返します。 {{domxref("XMLHTTPRequest.status")}} とは異なり、("200 OK" のように) レスポンスメッセージの完全な文が含まれています。

注: HTTP/2 仕様書 (8.1.2.4 レスポンス擬似ヘッダーフィールド) によれば、 HTTP/2 では、 HTTP/1.1 のステータス行に含まれていたバージョンや原因の文を伝える方法が定義されていません。

{{domxref("XMLHttpRequest.timeout")}}
リクエストを自動的に終了できるようになるまでの時間をミリ秒単位で表す、 unsigned long 型の値です。
{{domxref("XMLHttpRequestEventTarget.ontimeout")}}
リクエストがタイムアウトする都度呼び出される {{domxref("EventHandler")}}。{{gecko_minversion_inline("12.0")}}
{{domxref("XMLHttpRequest.upload")}} {{readonlyinline}}
アップロードプロセスを表す {{domxref("XMLHttpRequestUpload")}} です。
{{domxref("XMLHttpRequest.withCredentials")}}
{{domxref("Boolean")}} で、サイト間の Access-Control リクエストでクッキーや認証ヘッダーなどの資格情報を使用するかどうかを示します。

標準外のプロパティ

{{domxref("XMLHttpRequest.channel")}}{{ReadOnlyInline}}
{{Interface("nsIChannel")}} です。リクエストの実行の際にオブジェクトによって使われるチャンネルです。
{{domxref("XMLHttpRequest.mozAnon")}}{{ReadOnlyInline}}
boolean です。 true の場合、リクエストは cookie や認証ヘッダを伴わずに送信します。
{{domxref("XMLHttpRequest.mozSystem")}}{{ReadOnlyInline}}
boolean です。 true の場合、リクエストで同一オリジンポリシーは適用されません。
{{domxref("XMLHttpRequest.mozBackgroundRequest")}}
boolean です。オブジェクトがバックグラウンドサービスのリクエストであるかどうかを示します。
{{domxref("XMLHttpRequest.mozResponseArrayBuffer")}}{{gecko_minversion_inline("2.0")}} {{obsolete_inline("6")}} {{ReadOnlyInline}}
{{jsxref("ArrayBuffer")}} です。リクエストに対する、JavaScript typed array 形式でのレスポンスです。
{{domxref("XMLHttpRequest.multipart")}}{{obsolete_inline("22")}}
これは Gecko 独自の機能であり、 Firefox/Gecko 22 で削除されました。代わりに Server-Sent EventWeb Socket、または progress イベントの responseText を使用してください。

イベントハンドラー

onreadystatechangeXMLHttpRequest のインスタンスのプロパティとしてすべてのブラウザーが対応しています。

それ以来、数多くの追加のイベントハンドラーが様々なブラウザーに実装されてきています (onload, onerror, onprogress, など)。 XMLHttpRequest の使用を参照してください。

Firefox を含め、より新しいブラウザーでは、 XMLHttpRequest のイベントを on* プロパティをハンドラー関数に設定する方法に加えて、標準の {{domxref("EventTarget.addEventListener", "addEventListener()")}} API で待ち受けすることにも対応しています。

メソッド

{{domxref("XMLHttpRequest.abort()")}}
リクエストがすでに送信されている場合、リクエストを中止します。
{{domxref("XMLHttpRequest.getAllResponseHeaders()")}}
{{Glossary("CRLF")}} で区切られた文字列として、すべてのレスポンスヘッダを返します。レスポンスを何も受け取らなかった場合は null を返します。
{{domxref("XMLHttpRequest.getResponseHeader()")}}
指定したヘッダ文を含む文字列を返します。レスポンスを受信していない、またはレスポンス中に指定したヘッダが存在しない場合は null を返します。
{{domxref("XMLHttpRequest.open()")}}
リクエストを初期化します。このメソッドは JavaScript から使用するようにしてください。ネイティブコードからの初期化には、代わりに openRequest() を使用するようにしてください。
{{domxref("XMLHttpRequest.overrideMimeType()")}}
サーバーから返ってくる MIME タイプを上書きします。
{{domxref("XMLHttpRequest.send()")}}
リクエストを送信します。
{{domxref("XMLHttpRequest.setRequestHeader()")}}
HTTP リクエストヘッダーの値を設定します。 setRequestHeader()open() の後、および send() の前に呼び出さなくてはいけません。

標準外のメソッド

{{domxref("XMLHttpRequest.init()")}}
C++ コードから使用するために、オブジェクトを初期化します。
警告: JavaScript からこのメソッドを呼び出してはいけません
{{domxref("XMLHttpRequest.openRequest()")}}
リクエストを初期化します。このメソッドはネイティブコードから使用するためのものです。 JavaScript コードからの初期化には、代わりに open() を使用してください。 open() の項目を参照してください。
{{domxref("XMLHttpRequest.sendAsBinary()")}}{{deprecated_inline()}}
バイナリデータを送る、send() メソッドの亜種です。

イベント

{{domxref("XMLHttpRequest/abort_event", "abort")}}
例えばプログラムが {{domxref("XMLHttpRequest.abort()")}} を呼び出した時など、リクエストが中断されたときに発生します。
{{domxref("XMLHttpRequestEventTarget/onabort", "onabort")}} プロパティを通して利用することもできます。
{{domxref("XMLHttpRequest/error_event", "error")}}
リクエストでエラーが発生したときに発生します。
{{domxref("XMLHttpRequestEventTarget/onerror", "onerror")}} プロパティを通して利用することもできます。
{{domxref("XMLHttpRequest/load_event", "load")}}
{{domxref("XMLHttpRequest")}} のトランザクションが成功裏に完了したときに発生します。
{{domxref("XMLHttpRequestEventTarget/onload", "onload")}} プロパティを通して利用することもできます。
{{domxref("XMLHttpRequest/loadend_event", "loadend")}}
リクエストが完了したときに、成功した場合 ({{domxref("XMLHttpRequest/load_event", "load")}} の後)、成功しなかった場合 ({{domxref("XMLHttpRequest/abort_event", "abort")}} または {{domxref("XMLHttpRequest/error_event", "error")}} の後) のどちらでも発生します。
{{domxref("XMLHttpRequestEventTarget/onloadend", "onloadend")}} プロパティを通して利用することもできます。
{{domxref("XMLHttpRequest/loadstart_event", "loadstart")}}
リクエストがデータを読み込み始めたときに発生します。
{{domxref("XMLHttpRequestEventTarget/onloadstart", "onloadstart")}} プロパティを通して利用することもできます。
{{domxref("XMLHttpRequest/progress_event", "progress")}}
リクエストがもっとデータを受信した際に定期的に発生します。
{{domxref("XMLHttpRequestEventTarget/onprogress", "onprogress")}} プロパティを通して利用することもできます。
{{domxref("XMLHttpRequest/timeout_event", "timeout")}}
プリセット時間が過ぎたために進行が終了したときに発生します。
{{domxref("XMLHttpRequestEventTarget/ontimeout", "ontimeout")}} プロパティを通して利用することもできます。

仕様書

仕様書 状態 備考
{{SpecName('XMLHttpRequest')}} {{Spec2('XMLHttpRequest')}} Live standard 最新版

ブラウザーの互換性

{{Compat("api.XMLHttpRequest")}}

関連情報