如何检测浏览器是否支持深色模式

van*_*owm 6 javascript css browser darkmode

我们可以用来prefers-color-scheme: dark检测黑暗模式是否被激活:

const isDarkMode = window.matchMedia('(prefers-color-scheme: dark)').matches;
Run Code Online (Sandbox Code Playgroud)

有没有办法检测浏览器是否支持深色模式?(“支持深色模式”是指浏览器自动更改网页的默认背景/文本颜色)。

在 CSS 中,我们可以强制使用深色模式

color-scheme: dark;
Run Code Online (Sandbox Code Playgroud)

但是,某些浏览器(Android 版 Firefox)会忽略它。因此,如果黑暗模式不可用,我想隐藏主题选择。

van*_*owm 0

我当前的解决方案是在深色和浅色模式之间切换,并检查模式之间的默认颜色是否已更改:

const hasDarkMode = function()
{
  const el = document.createElement("div");
  el.style.display = "none";
  document.body.appendChild(el);
  let color;
  /*canvastext - doesn't work in Samsung Internet, initial/unset - doesn't work in Firefox*/
  for(let i = 0, c = ["canvastext", "initial", "unset"]; i < c.length; i++ )
  {
    el.style.color = c[i];
    el.style.colorScheme = "dark";
    color = getComputedStyle(el).color;
    el.style.colorScheme = "light";
    color = color != getComputedStyle(el).color;
    if (color)
      break;
  }
  document.body.removeChild(el);
  return color;
}();

console.log("Dark mode supported:", hasDarkMode);
Run Code Online (Sandbox Code Playgroud)

这可能不是最优雅的解决方案,但它似乎有效。

根据 @connexo 的评论,我们还可以测试:

const hasDarkMode = CSS.supports("color-scheme", "dark");

console.log("Dark mode supported:", hasDarkMode);
Run Code Online (Sandbox Code Playgroud)
@supports (color-scheme: dark)
{
  .no-dark-mode
  {
    display: none;
  }
}
Run Code Online (Sandbox Code Playgroud)
<div>Dark mode is <span class="no-dark-mode">not </span>available</div>
Run Code Online (Sandbox Code Playgroud)