您现在的位置是:网站首页> 编程资料编程资料
使用CSS实现黑暗模式和高亮模式的切换功能CSS中引用svg图片支持动态切换颜色的实现代码基于Css Variable的主题切换完美解决方案(推荐)详解如何简单实现CSS主题的切换纯css实现选中切换效果的示例纯CSS免费让网站拥有暗黑模式切换功能的实现代码
2023-10-19
248人已围观
简介 这两个概念是来源于 macOS系统 ,该系统为用户提供两个主题皮肤,即 高亮 和 暗色 系的皮肤。接下来通过本文给大家分享使用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 :
在代码中提供一个简单的脚本函数:
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实现黑暗模式和高亮模式的切换功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家!
相关内容
- CSS使用placeholder-shown伪类实现输入框浮动文字效果css浮动 float属性详解CSS实现元素浮动和清除浮动的方法纯CSS3+SVG实现的机器人悬浮动画效果源码html/css中float浮动的用法实例详解Css实现清除浮动的方法汇总什么是BFC? CSS 使用伪元素清除浮动的方法CSS3 清除浮动的方法示例CSS 清除浮动与BFC的方法
- css 权重值(层叠性)实例详解 CSS中选择器的权重值的计算浅谈CSS中的继承性,特殊性,层叠性和重要性
- 如何反转CSS中的贝塞尔曲线的实现方法CSS 曲线阴影实现的示例代码CSS3实现曲线阴影和翘边阴影
- CSS3中媒体查询结合rem布局适配手机屏幕纯js和CSS3媒体查询制作简单的响应式导航菜单特效源码详解CSS3 Media Queries中媒体属性的使用 CSS3媒体查询Media Queries基础学习教程使用CSS媒体查询(Media Queries)和JavaScript判断浏览器设备类型的方法CSS3媒体查询(Media Queries)介绍css3 响应式媒体查询的示例代码
- CSS Sticky Footer 几种实现方式
- css等高布局常用几种方式css多种方式实现等高布局的示例代码css设置多列等高布局的方法示例前端应该掌握的CSS实现多列等高布局技巧利用CSS3的flexbox实现水平垂直居中与三列等高布局浅析CSS等高布局的6种方式用CSS实现三列DIV等高布局以传达更好的视觉效果CSS 三栏等高布局实现方法CSS实例:三列等高布局-CSS教程-网页制作-网页教学网
- 全民飞机大战叉叉助手破百万不异常教程_刷金币刷分心得_手机游戏_游戏攻略_
- 全民飞机大战战机满级弹道所有战机满级弹道表一览_手机游戏_游戏攻略_
- 天天酷跑1月24日UU助手不异常教程攻略_ios版刷金币刷分心得_手机游戏_游戏攻略_
- 天天酷跑ios版刷金币刷分心得_1.0.8.0版不异常教程攻略_手机游戏_游戏攻略_
