Window: load Event
Baseline
Weitgehend verfügbar
Diese Funktion ist gut etabliert und funktioniert auf vielen Geräten und in vielen Browserversionen. Sie ist seit Juli 2015 browserübergreifend verfügbar.
Das load-Ereignis wird ausgelöst, wenn die gesamte Seite geladen wurde, einschließlich aller abhängigen Ressourcen wie Stylesheets, Skripte (einschließlich asynchroner, verzögerter und Modulscripte), iframes und Bilder, mit Ausnahme derjenigen, die lazy geladen sind.
Dies steht im Gegensatz zum DOMContentLoaded, das ausgelöst wird, sobald das DOM der Seite geladen ist, ohne darauf zu warten, dass Ressourcen das Laden abgeschlossen haben.
Dieses Ereignis kann nicht abgebrochen werden und propagiert nicht.
Hinweis:
Alle Ereignisse mit dem Namen load werden nicht an Window weitergereicht, selbst wenn bubbles auf true gesetzt ist. Um load-Ereignisse am window zu erfassen, muss dieses load-Ereignis direkt auf das window gesendet werden.
Hinweis:
Das load-Ereignis, das ausgelöst wird, wenn das Hauptdokument geladen ist, wird auf dem window ausgelöst, hat jedoch zwei veränderte Eigenschaften: target ist document, und path ist undefined. Diese beiden Eigenschaften sind aufgrund von Legacy-Konformität verändert.
Um zu vermeiden, dass ein Script ausgeführt wird, bevor das DOM, das es manipuliert, vollständig aufgebaut ist, kann das Script am Ende des Dokumententextes direkt vor dem schließenden </body>-Tag platziert werden, ohne es in einen Ereignis-Listener zu wickeln. Normalerweise sollten Sie das load-Ereignis nur verwenden, um auf das Laden externer Ressourcen wie Bilder oder verzögerte Skripte zu warten.
Syntax
Verwenden Sie den Ereignisnamen in Methoden wie addEventListener() oder setzen Sie eine Ereignishandler-Eigenschaft.
addEventListener("load", (event) => { })
onload = (event) => { }
Ereignistyp
Ein generisches Event.
Beispiele
Protokollieren Sie eine Nachricht, wenn die Seite vollständig geladen ist:
window.addEventListener("load", (event) => {
console.log("page is fully loaded");
});
Das Gleiche, aber mit der onload-Ereignishandler-Eigenschaft:
window.onload = (event) => {
console.log("page is fully loaded");
};
Live-Beispiel
HTML
<div class="controls">
<button id="reload" type="button">Reload</button>
</div>
<div class="event-log">
<label for="eventLog">Event log:</label>
<textarea
readonly
class="event-log-contents"
rows="8"
cols="30"
id="eventLog"></textarea>
</div>
JavaScript
const log = document.querySelector(".event-log-contents");
const reload = document.querySelector("#reload");
reload.addEventListener("click", () => {
log.textContent = "";
setTimeout(() => {
window.location.reload(true);
}, 200);
});
window.addEventListener("load", (event) => {
log.textContent += "load\n";
});
document.addEventListener("readystatechange", (event) => {
log.textContent += `readystate: ${document.readyState}\n`;
});
document.addEventListener("DOMContentLoaded", (event) => {
log.textContent += `DOMContentLoaded\n`;
});
Ergebnis
Spezifikationen
| Spezifikation |
|---|
| UI Events> # event-type-load> |
| HTML> # delay-the-load-event> |
Browser-Kompatibilität
Siehe auch
- Document readyState API
- Verwandte Ereignisse: