Skip to content

Instantly share code, notes, and snippets.

@Oscar-Arias2001
Last active December 17, 2025 19:04
Show Gist options
  • Select an option

  • Save Oscar-Arias2001/c0fb9fc1629ba6cea23f27d7b4713c18 to your computer and use it in GitHub Desktop.

Select an option

Save Oscar-Arias2001/c0fb9fc1629ba6cea23f27d7b4713c18 to your computer and use it in GitHub Desktop.
This code detects which image formats the browser supports and adds classes to the <html> based on the result.
"use strict";
(function (document) {
let checkCount = 0,
formatFound = false;
const setHTMLClass = (height, className) => {
checkCount++;
if (height == 2) {
formatFound = true;
document.documentElement.className += " " + className;
} else {
document.documentElement.className += " not" + className;
if (checkCount == 4 && !formatFound)
document.implementation.hasFeature(
"http://www.w3.org/TR/SVG11/feature#Image",
"1.1"
)
? (document.documentElement.className += " svg")
: (document.documentElement.className += " notsvg png");
}
};
let JXL = new Image();
JXL.onload = JXL.onerror = () => setHTMLClass(JXL.height, "jxl");
JXL.src =
"";
let AVIF = new Image();
AVIF.onload = AVIF.onerror = () => setHTMLClass(AVIF.height, "avif");
AVIF.src =
"";
let WebP = new Image();
WebP.onload = WebP.onerror = () => setHTMLClass(WebP.height, "webp");
WebP.src =
"";
let JPX = new Image();
JPX.onload = JPX.onerror = () => setHTMLClass(JPX.height, "jpx");
JPX.src =
"";
let JP2 = new Image();
JP2.onload = JP2.onerror = () => setHTMLClass(JP2.height, "jp2");
JP2.src =
"";
})(
(window.sandboxApi &&
window.sandboxApi.parentWindow &&
window.sandboxApi.parentWindow.document) ||
document
);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment