Document: readystatechange event
{{APIRef}}
The readystatechange
event is fired when the {{domxref("Document.readyState", "readyState")}}
attribute of a document has changed.
This event is not cancelable and does not bubble.
Syntax
Use the event name in methods like {{domxref("EventTarget.addEventListener", "addEventListener()")}}
, or set an event handler property.
addEventListener("readystatechange", (event) => {});
onreadystatechange = (event) => {};
Event type
A generic {{domxref("Event")}}
.
Examples
Live example
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>
CSS
body {
display: grid;
grid-template-areas: "control log";
}
.controls {
grid-area: control;
display: flex;
align-items: center;
justify-content: center;
}
.event-log {
grid-area: log;
}
.event-log-contents {
resize: none;
}
label,
button {
display: block;
}
#reload {
height: 2rem;
}
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 = `${log.textContent}load\n`;
});
document.addEventListener("readystatechange", (event) => {
log.textContent = `${log.textContent}readystate: ${document.readyState}\n`;
});
document.addEventListener("DOMContentLoaded", (event) => {
log.textContent = `${log.textContent}DOMContentLoaded\n`;
});
Result
{{ EmbedLiveSample('Live_example', '100%', '160px') }}
Specifications
{{Specifications}}
Browser compatibility
{{Compat}}
See also
- Related events:
DOMContentLoaded
,load
,beforeunload
,unload