FrontendDeveloper.in

JavaScript question detail

How to detect system dark mode in javascript?

The combination of Window.matchMedia() utility method along with media query is used to check if the user has selected a dark color scheme in their operating system settings or not. The CSS media query prefers-color-scheme needs to be passed to identify system color theme.

The following javascript code describes the usage,

const hasDarkColorScheme = () =>
window.matchMedia &&
window.matchMedia("(prefers-color-scheme: dark)").matches;

You can also watch changes to system color scheme using addEventListener,

window
.matchMedia("(prefers-color-scheme: dark)")
.addEventListener("change", (event) => {
const theme = event.matches ? "dark" : "light";
});

Note: The matchMedia method returns MediaQueryList object stores information from a media query.

Back to all JavaScript questions
Get LinkedIn Premium at Rs 399