头闻号

深圳市吉田化工有限公司

萜烯树脂T-100/120,特级松香,C5/C9石油树脂,氢化石油树脂,增粘树脂138、801,酚醛树...

首页 > 新闻中心 > 科技常识:使用CSS实现黑暗模式和高亮模式的切换功能
科技常识:使用CSS实现黑暗模式和高亮模式的切换功能
发布时间:2025-02-20 09:43:04        浏览次数:7        返回列表

今天小编跟大家讲解下有关使用CSS实现黑暗模式和高亮模式的切换功能 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关使用CSS实现黑暗模式和高亮模式的切换功能 的相关资料,希望小伙伴们看了有所帮助。

在 Web技巧 的第五期中专门提到一个有关于CSS实现黑暗模式和高亮模式的技术方案。即使用新的媒体查询条件 prefers-color-scheme 的值 dark 和 light 来进行切换 这是从最底层也是最原生的解决方案 除此之外还可以通过CSS的混合模式属性来模拟。当然 除了期刊中提到的技术方案之外 还有其他的一些解决方案。今天我们就来一起学习一下 如何实现黑暗模式和高亮模式之间的切换。

什么是黑暗模式和高亮模式

在聊技术方案之前先来简单地了解什么是黑暗模式和高亮模式 这两个概念是来源于 macOS系统 该系统为用户提供两个主题皮肤 即 高亮 和 暗色 系的皮肤。自从有了这个概念之后 很多网站都会用户提供了相应的两套肤色 便于用户根据自己的习惯或爱好进行切换。

不管是黑暗模式还是高亮模式 都是黑白色之间的切换 这种主题风格对于有色盲的用户群体而言是非常有友好的。

类似这样的功能 在其他的系统或者软件中都略有身影 不同之处是提供的模式。在一些软件中 可能会给用户提供一些皮肤自定制的功能。当然在网站上也有类似的功能 只不过我们以往可能更喜欢把这种功能称为 网站换肤 。

这样一来 我们就可以把这两者模式之间的切换先按换肤来聊 可能会更切合我们的业务场景。接下来我们来聊聊技术上面的事情 即 如何使用CSS来完成Web页面或应用程序的主题切换!

最简模式

假设你的主题默认是高亮模式 我们可以使用一种最为简单粗暴的方式将高亮模式切换到黑暗模式。假设在Web页面有一个入口 让用户点击这个 button 时会给 html 元素添加一个 dark-theme 类名:

document.getElementById('buttonID').addEventListener('click', function(){ document.documentElement.classList.add('dark-theme')})

在 .dark-theme 以及他所有后代元素上添加暗黑色样式:

.dark-theme { background-color: #000; color: white;}.dark-theme *:not(a) { background-color: #000 !important; color: #fff !important; border-color: #999 !important;}

这种方式虽为简单粗暴 但有些细节需要额外处理 特别是代码中也有使用 !important 的样式时 会较为头痛。另外对于其他涉及到颜色的元素有可能需要额外处理。

准备两套样式

在我个人的印象之中 最早实现类似的效果 一般都是通过Javascript来更换Web页面或Web应用程序主题皮肤的 .css 文件:

正如上图所示 提供了两个CSS文件 一个是 theme1.css 另一个是 theme2.css 同时提供用户可切换的入口 当用户选择对应的主题之后 Web页面或Web应用程序就会切换到相应的 .css 从而看到的就是对应的主题肤色效果。

假设Web页面默认的主题风格是运用的 theme1.css :

<link type="text/css" rel="stylesheet" media="all" href="../theme1.css" id="theme_css" />

在代码中提供一个简单的脚本函数:

document.getElementById('buttonID').addEventListener('click', function(){ document.getElementById('theme_css').href = '../theme2.css';})

回到我们主题中来 如果你需要黑暗模式和高亮模式之间的切换 那可以按类似的原理 分别提供 dark.css 和 light.css 。

对于维护多套样式是较为痛苦的 特别当你要为你的产品提供更多的皮肤的时候更为堪忧。这个时候你可以借助类似Sass这样的处理器来维护你的主题样式 声明好变量 然后维护对应的变量值 好比Bootstrap主题的构建一样 他就使用了Sass的变量 :

有关于Sass来管理多套皮肤相关的知识已超出本文要探讨的范围 如果你对这方面知识感兴趣的话 可以阅读下面文章:

Organizing Multiple Theme Styles with Sass

总结

以上所述是小编给大家介绍的使用CSS实现黑暗模式和高亮模式的切换功能 希望对大家有所帮助 如果大家有任何疑问欢迎给我留言 小编会及时回复大家!

来源:爱蒂网