HTTP/2 302
x-cloud-trace-context: 1255541fc373136e5c634136d5fc8bf9
location: /en-US/docs/Web/API/Document/readyState
via: 1.1 google, 1.1 varnish, 1.1 varnish, 1.1 varnish, 1.1 varnish
accept-ranges: bytes
cache-control: no-store
server: Google Frontend
content-type: text/plain; charset=utf-8
date: Fri, 26 Dec 2025 11:07:31 GMT
x-served-by: cache-bfi-krnt7300036-BFI, cache-bfi-krnt7300036-BFI, cache-sin-wsat1880078-SIN, cache-bom-vanm7210034-BOM
x-cache: MISS, MISS, MISS, MISS
x-cache-hits: 0, 0, 0, 0
x-timer: S1766747251.304714,VS0,VE399
vary: Accept
content-length: 61
HTTP/2 200
x-goog-stored-content-length: 172003
x-goog-metageneration: 1
referrer-policy: strict-origin-when-cross-origin
expires: Fri, 26 Dec 2025 02:26:47 GMT
x-goog-hash: crc32c=ajMAGQ==, md5=xBDgvC6X5unLIhc71Xh2Dg==
content-security-policy: default-src 'self'; script-src 'report-sample' 'self' 'wasm-unsafe-eval' https://www.google-analytics.com/analytics.js https://*.googletagmanager.com assets.codepen.io production-assets.codepen.io https://js.stripe.com 'sha256-XNBp89FG76amD8BqrJzyflxOF9PaWPqPqvJfKZPCv7M=' 'sha256-YCNoU9DNiinACbd8n6UPyB/8vj0kXvhkOni9/06SuYw=' 'sha256-PZjP7OR6mBEtnvXIZfCZ5PuOlxoDF1LDZL8aj8c42rw='; script-src-elem 'report-sample' 'self' 'wasm-unsafe-eval' https://www.google-analytics.com/analytics.js https://*.googletagmanager.com assets.codepen.io production-assets.codepen.io https://js.stripe.com 'sha256-XNBp89FG76amD8BqrJzyflxOF9PaWPqPqvJfKZPCv7M=' 'sha256-YCNoU9DNiinACbd8n6UPyB/8vj0kXvhkOni9/06SuYw=' 'sha256-PZjP7OR6mBEtnvXIZfCZ5PuOlxoDF1LDZL8aj8c42rw='; style-src 'report-sample' 'self' 'unsafe-inline'; object-src 'none'; base-uri 'self'; connect-src 'self' developer.allizom.org bcd.developer.allizom.org bcd.developer.mozilla.org updates.developer.allizom.org updates.developer.mozilla.org https://*.google-analytics.com https://*.analytics.google.com https://*.googletagmanager.com https://incoming.telemetry.mozilla.org https://observatory-api.mdn.allizom.net https://observatory-api.mdn.mozilla.net https://api.github.com/search/issues stats.g.doubleclick.net https://api.stripe.com; font-src 'self'; frame-src 'self' mdn.github.io *.mdnplay.dev *.mdnyalp.dev *.play.test.mdn.allizom.net https://v2.scrimba.com https://scrimba.com jsfiddle.net www.youtube-nocookie.com codepen.io survey.alchemer.com https://js.stripe.com; img-src 'self' data: *.githubusercontent.com *.googleusercontent.com *.gravatar.com mozillausercontent.com firefoxusercontent.com profile.stage.mozaws.net profile.accounts.firefox.com developer.mozilla.org mdn.dev wikipedia.org upload.wikimedia.org https://mdn.github.io/shared-assets/ https://mdn.dev/ https://*.google-analytics.com https://*.googletagmanager.com www.gstatic.com; manifest-src 'self'; media-src 'self' archive.org videos.cdn.mozilla.net https://mdn.github.io/shared-assets/; child-src 'self'; worker-src 'self';
x-goog-meta-goog-reserved-file-mtime: 1766709867
x-frame-options: DENY
x-goog-stored-content-encoding: identity
x-goog-generation: 1766711049660291
via: 1.1 google, 1.1 varnish, 1.1 varnish, 1.1 varnish, 1.1 varnish
server: Google Frontend
origin-trial: AxVILwizhbMjxFeHOn1P3R8niO1RJY/smaK4B4d1rLzc1gTaxtXMSaTi+FoigYgCw40uFRDwFcEAeqDR+vVLOW4AAABfeyJvcmlnaW4iOiJodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZyIsImZlYXR1cmUiOiJQcml2YXRlQXR0cmlidXRpb25WMiIsImV4cGlyeSI6MTc0MjA3OTYwMH0=
last-modified: Fri, 26 Dec 2025 01:04:09 GMT
x-goog-storage-class: STANDARD
x-cloud-trace-context: e98cffe6ddb48ec3e01e3794decd82dd
x-content-type-options: nosniff
content-type: text/html
etag: "c410e0bc2e97e6e9cb22173bd578760e"
cache-control: public, max-age=3600
x-guploader-uploadid: AHVrFxN9sJnX421iz86ORssCUzDdWGytdoEZKO_ptFBpqfEaZWvQEPsIhOTGPcJZBVNiwfuYM5rtjRs
strict-transport-security: max-age=63072000
content-encoding: gzip
accept-ranges: bytes
age: 0
date: Fri, 26 Dec 2025 11:07:32 GMT
x-served-by: cache-bfi-kbfi7400058-BFI, cache-bfi-kbfi7400066-BFI, cache-sin-wsat1880045-SIN, cache-bom-vanm7210034-BOM
x-cache: MISS, MISS, HIT, MISS
x-cache-hits: 0, 0, 7, 0
x-timer: S1766747252.717476,VS0,VE296
vary: Accept-Encoding
content-length: 21996
Document: readyState property - Web APIs | MDN
The readyState of a document can be one of following:
loading
The document is still loading (that is, the HTML parser is still working).
interactive
The document has been parsed but sub-resources such as deferred and module scripts, images, stylesheets, and frames are still loading. Once in this state, and the deferred and module scripts have executed, the DOMContentLoaded event fires.
complete
The document and all sub-resources have finished loading. The state indicates that the load event is about to fire.
switch (document.readyState) {
case "loading":
// The document is loading.
break;
case "interactive": {
// The document has finished loading and we can access DOM elements.
// Sub-resources such as scripts, images, stylesheets and frames are still loading.
const span = document.createElement("span");
span.textContent = "A <span> element.";
document.body.appendChild(span);
break;
}
case "complete":
// The page is fully loaded.
console.log(
`The first CSS rule is: ${document.styleSheets[0].cssRules[0].cssText}`,
);
break;
}
// Alternative to DOMContentLoaded event
document.onreadystatechange = () => {
if (document.readyState === "interactive") {
initApplication();
}
};
// Alternative to load event
document.onreadystatechange = () => {
if (document.readyState === "complete") {
initApplication();
}
};
document.addEventListener("readystatechange", (event) => {
if (event.target.readyState === "interactive") {
initLoader();
} else if (event.target.readyState === "complete") {
initApp();
}
});
Enable JavaScript to view this browser compatibility table.