
本文将介绍一种简单易懂的方法实现网站支持暗黑模式,话不多说,我们开始吧!以以下新闻应用程序为例:

现在仅需增加以下一行魔法 CSS:
html[theme='dark-mode'] {
filter: invert(1) hue-rotate(180deg);
}
添加后页面展示效果:

哇偶! 瞬间转换成暗黑模式有没有
filter CSS 属性将模糊或颜色偏移等图形效果应用于元素。滤镜通常用于调整图像,背景和边框的渲染。(参考: MDN Web 文档 )
对于暗黑模式,将使用两个 filter : invert 和 hue-rotate

这个方法的唯一缺点是,它还会反转应用程序中的所有图像。因此,我们将对所有图像添加相同的规则,以逆转效果。
html[theme='dark-mode'] img{
filter: invert(1) hue-rotate(180deg);
}
我们还将向 HTML 元素添加一个 transition ,以确保过渡不会过于花哨!
html {
transition: color 300ms, background-color 300ms;
}
实现结果:


