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)会忽略它。因此,如果黑暗模式不可用,我想隐藏主题选择。
我当前的解决方案是在深色和浅色模式之间切换,并检查模式之间的默认颜色是否已更改:
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)