一行 CSS 为网页添加暗黑模式支持

发布于 2024-12-04 12:45:59 字数 1523 浏览 9 评论 0

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

现在仅需增加以下一行魔法 CSS:

html[theme='dark-mode'] {
    filter: invert(1) hue-rotate(180deg);
}

添加后页面展示效果:

哇偶! 瞬间转换成暗黑模式有没有

解析

filter CSS 属性将模糊或颜色偏移等图形效果应用于元素。滤镜通常用于调整图像,背景和边框的渲染。(参考: MDN Web 文档

对于暗黑模式,将使用两个 filterinverthue-rotate

  • invert :反转配色。黑色变为白色,白色变为黑色,所有颜色都是如此
  • hue-rotate :帮助我们处理所有其他非黑色和白色的颜色。 将色相旋转 180 度,我们确保应用程序的颜色主题不会改变,而只是减弱其颜色。

这个方法的唯一缺点是,它还会反转应用程序中的所有图像。因此,我们将对所有图像添加相同的规则,以逆转效果。

html[theme='dark-mode'] img{
    filter: invert(1) hue-rotate(180deg);
}

我们还将向 HTML 元素添加一个 transition ,以确保过渡不会过于花哨!

html {
    transition: color 300ms, background-color 300ms;
}

实现结果:

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

0 文章
0 评论
24 人气
更多

推荐作者

已经忘了多久

文章 0 评论 0

15867725375

文章 0 评论 0

LonelySnow

文章 0 评论 0

走过海棠暮

文章 0 评论 0

轻许诺言

文章 0 评论 0

信馬由缰

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文