iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何使用CSS实现黑暗模式和高亮模式的切换功能
  • 635
分享到

如何使用CSS实现黑暗模式和高亮模式的切换功能

2023-06-08 06:06:40 635人浏览 独家记忆
摘要

这篇文章给大家分享的是有关如何使用CSS实现黑暗模式和高亮模式的切换功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。什么是黑暗模式和高亮模式在聊技术方案之前先来简单地了解什么是黑暗模式和高亮模式?这两个概念是来

这篇文章给大家分享的是有关如何使用CSS实现黑暗模式和高亮模式的切换功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

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

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

如何使用CSS实现黑暗模式和高亮模式的切换功能

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

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

如何使用CSS实现黑暗模式和高亮模式的切换功能

这样一来,我们就可以把这两者模式之间的切换先按换肤来聊,可能会更切合我们的业务场景。接下来我们来聊聊技术上面的事情,即 如何使用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;}

如何使用CSS实现黑暗模式和高亮模式的切换功能

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

准备两套样式

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

如何使用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.csslight.css

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

如何使用CSS实现黑暗模式和高亮模式的切换功能

感谢各位的阅读!关于“如何使用CSS实现黑暗模式和高亮模式的切换功能”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: 如何使用CSS实现黑暗模式和高亮模式的切换功能

本文链接: https://www.lsjlt.com/news/252218.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何使用CSS实现黑暗模式和高亮模式的切换功能
    这篇文章给大家分享的是有关如何使用CSS实现黑暗模式和高亮模式的切换功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。什么是黑暗模式和高亮模式在聊技术方案之前先来简单地了解什么是黑暗模式和高亮模式?这两个概念是来...
    99+
    2023-06-08
  • CSS变量如何实现暗黑模式
    这篇文章主要介绍CSS变量如何实现暗黑模式,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!使用 CSS变量 和 @media查询 实现暗黑模式。 CSS Dark Mode我定义了变量以设置主题的颜色,我建议...
    99+
    2023-06-08
  • 基于vue3和element-plus的暗黑模式如何实现
    这篇文章主要介绍“基于vue3和element-plus的暗黑模式如何实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于vue3和element-plus的暗黑模式如何实现”文章能帮助大家解决问...
    99+
    2023-07-06
  • 如何在Vue Vite应用程序中实现暗/亮模式
    这篇文章主要为大家展示了“如何在Vue Vite应用程序中实现暗/亮模式”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何在Vue Vite应用程序中实现暗/亮...
    99+
    2024-04-02
  • 基于vue3和element-plus的暗黑模式怎么实现
    本篇内容介绍了“基于vue3和element-plus的暗黑模式怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、基本使用因为是通过...
    99+
    2023-07-04
  • Windows7暗藏的管理功能之上帝模式如何调用
      GodMode的字面释义是:上帝模式。能够以此冠名,想来定有其非常之处。   简单来说,上帝模式可以理解为一个快捷方式;能籍其实现对系统设定的集中控制,让操作变得更简洁;只需鼠标轻轻一点,几乎所有设置,都可在一个窗口...
    99+
    2023-06-02
    win7 管理功能 上帝模式 功能 上帝 管理 Windows7 模式
  • Python设计模式中如何使用状态模式实现编辑功能
    Python设计模式中如何使用状态模式实现编辑功能,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。功能介绍新增对象选择,连接线编辑功能。新增对象选择状态表示,连接...
    99+
    2023-06-19
  • java单例模式如何实现面板切换
    这篇文章主要为大家展示了“java单例模式如何实现面板切换”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“java单例模式如何实现面板切换”这篇文章吧。具体内容如下首先介绍一下什么是单例模式:  ...
    99+
    2023-05-30
    java
  • JavaWeb如何使用mvc模式实现登录功能
    这篇文章给大家分享的是有关JavaWeb如何使用mvc模式实现登录功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。部署项目、环境搭建 详细内容  1.导包  &...
    99+
    2023-06-29
  • 如何实现在Linux中模式切换与用户登陆
    本篇内容介绍了“如何实现在Linux中模式切换与用户登陆”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!<1> X Window ...
    99+
    2023-06-12
  • JavaWeb使用mvc模式实现登录功能
    目录部署项目、环境搭建 详细内容 登录实现部署项目、环境搭建  详细内容   1.导包     ...
    99+
    2024-04-02
  • 如何使用JavaScript实现模板方法模式
    模板方法模式是一种行为设计模式,它是指将一个算法的骨架定义在一个操作中,将一些步骤延迟到子类中实现。模板方法使得子类可以在不改变算法结构的情况下重新定义算法的某些步骤。在本文中,我们将介绍如何使用 JavaScript 实现模板方法模式。实...
    99+
    2023-05-14
  • 在Ubuntu中如何使用Slimbook Battery Optimizer切换电源模式
    这篇文章主要为大家展示了“在Ubuntu中如何使用Slimbook Battery Optimizer切换电源模式”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“在Ubuntu中如何使用Slimb...
    99+
    2023-06-16
  • 如何使用Javascript实现单例模式
    这篇文章给大家分享的是有关如何使用Javascript实现单例模式的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。JavaScript是什么JavaScript是一种直译式的脚本语言,其解释器被称为JavaScri...
    99+
    2023-06-14
  • 如何使用Spring实现策略模式
    本篇内容介绍了“如何使用Spring实现策略模式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Spring 中 @Autowired注解,大...
    99+
    2023-06-27
  • 如何使用CSS3实现选项卡切换功能
    这篇文章主要讲解了“如何使用CSS3实现选项卡切换功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用CSS3实现选项卡切换功能”吧!:target是...
    99+
    2024-04-02
  • 如何使用策略模式与装饰模式扩展JavaScript表单验证功能
    这篇文章主要介绍了如何使用策略模式与装饰模式扩展JavaScript表单验证功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。简单的表单验证...
    99+
    2024-04-02
  • 如何使用Dreamweaver的代码模式来编写DIV和CSS
    这篇文章主要介绍了如何使用Dreamweaver的代码模式来编写DIV和CSS的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何使用Dreamweaver的代码模式来编写DIV...
    99+
    2024-04-02
  • CentOS7如何使用hostapd实现无AP模式
    这篇文章主要介绍了CentOS7如何使用hostapd实现无AP模式,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。这篇是 linux 下使用 hostapd 实现无...
    99+
    2023-06-10
  • 如何使用PHP实现观察者模式
    小编给大家分享一下如何使用PHP实现观察者模式,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!观察者模式为您提供了避免组件之间紧密...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作