--- title: 'XMLHttpRequest: loadend イベント' slug: Web/API/XMLHttpRequest/loadend_event tags: - API - Event - NeedsCompatTable - NeedsSpecTable - ProgressEvent - Reference - Web - events - loadend - イベント translation_of: Web/API/XMLHttpRequest/loadend_event ---
{{APIRef}}

loadend イベントは、リクエストが完了したときに、成功した場合 ({{domxref("XMLHttpRequest/load_event", "load")}} の後)、成功しなかった場合 ({{domxref("XMLHttpRequest/abort_event", "abort")}} または {{domxref("XMLHttpRequest/error_event", "error")}} の後) のどちらでも発生します。

バブリング なし
キャンセル可能 いいえ
インターフェイス {{domxref("ProgressEvent")}}
イベントハンドラープロパティ {{domxref("XMLHttpRequestEventTarget/onloadend", "onloadend")}}

ライブデモ

HTML

<div class="controls">
    <input class="xhr success" type="button" name="xhr" value="Click to start XHR (success)" />
    <input class="xhr error" type="button" name="xhr" value="Click to start XHR (error)" />
    <input class="xhr abort" type="button" name="xhr" value="Click to start XHR (abort)" />
</div>

<textarea readonly class="event-log"></textarea>

JS

const xhrButtonSuccess = document.querySelector('.xhr.success');
const xhrButtonError = document.querySelector('.xhr.error');
const xhrButtonAbort = document.querySelector('.xhr.abort');
const log = document.querySelector('.event-log');

function handleEvent(e) {
    log.textContent = log.textContent + `${e.type}: ${e.loaded} bytes transferred\n`;
}

function addListeners(xhr) {
    xhr.addEventListener('loadstart', handleEvent);
    xhr.addEventListener('load', handleEvent);
    xhr.addEventListener('loadend', handleEvent);
    xhr.addEventListener('progress', handleEvent);
    xhr.addEventListener('error', handleEvent);
    xhr.addEventListener('abort', handleEvent);
}

function runXHR(url) {
    log.textContent = '';

    const xhr = new XMLHttpRequest();
    addListeners(xhr);
    xhr.open("GET", url);
    xhr.send();
    return xhr;
}

xhrButtonSuccess.addEventListener('click', () => {
    runXHR('https://mdn.mozillademos.org/files/16553/DgsZYJNXcAIPwzy.jpg');
});

xhrButtonError.addEventListener('click', () => {
    runXHR('https://somewhere.org/i-dont-exist');
});

xhrButtonAbort.addEventListener('click', () => {
    runXHR('https://mdn.mozillademos.org/files/16553/DgsZYJNXcAIPwzy.jpg').abort();
});

結果

{{ EmbedLiveSample('Live_example', '100%', '150px') }}

仕様書

仕様書 状態 備考
{{SpecName('XMLHttpRequest', '#event-xhr-loadend')}} {{Spec2('XMLHttpRequest')}}  

ブラウザーの対応

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

関連情報