Home > Web Front-end > CSS Tutorial > How Can You Detect Dark Mode in JavaScript?

How Can You Detect Dark Mode in JavaScript?

Linda Hamilton
Release: 2024-11-14 15:36:01
Original
440 people have browsed it

How Can You Detect Dark Mode in JavaScript?

Detecting Dark Mode in JavaScript

Many modern operating systems like Windows and macOS offer dark mode as an option to enhance user experience and reduce eye strain in low-light settings. As a developer, it's beneficial to be able to detect the preferred color scheme of the user's operating system to provide a seamless user experience.

CSS Media Queries for Dark Mode

For CSS, the @media (prefers-dark-interface) media query can be used to apply styles specifically for dark mode. However, when using APIs like Stripe Elements that utilize JavaScript for styling, a different approach is needed.

JavaScript Solution

To determine the operating system's preferred color scheme in JavaScript, you can use the following code:

if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
  // dark mode detected
}
Copy after login

This code utilizes the window.matchMedia() API to check if the user's browser supports media queries and whether the '(prefers-color-scheme: dark)' media query is matched. If the query matches, it indicates that the user has enabled dark mode on their operating system.

Monitoring Color Scheme Changes

If you need to respond to changes in the user's color scheme preferences, you can use the addEventListener() method to listen for events on the media query. The following code adds an event listener that will trigger a callback function whenever the color scheme changes:

window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', event => {
  const newColorScheme = event.matches ? "dark" : "light";
  // Perform necessary actions based on the new color scheme
});
Copy after login

By utilizing these techniques, you can effectively detect and respond to the user's preferred color scheme, ensuring a consistent and optimized user experience regardless of whether they're using light or dark mode.

The above is the detailed content of How Can You Detect Dark Mode in JavaScript?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template