前端换肤,聊一聊主题切换那些事

简介: 前端换肤,聊一聊主题切换那些事

一些网站通常会提供白天、夜间模式,以及自定义主题等等,这种主题切换也就是本文说的前端换肤。

这次案例用的是白天和夜间模式的切换,在做换肤之前,得先知道一件事情:css的变量定义,对变量定义不熟悉的同学请看MDN文档:自定义属性(–*):CSS 变量

主题切换也就是样式的切换,白天和黑夜的模式切换需要准备两套样式,我们通过css的变量定义,全局访问这些公共变量就可以实现主题切换。

此处我已经准备好了样式:

/*style.css*/
/* 基本样式 */
:root {
  --theme-background: #ecf5ff; /*背景色*/
  --theme-menuBackground : #fff; /*菜单颜色*/
  --theme-menuIcon : #303133; /*菜单icon*/
}
/* 黑夜模式 */
html[theme-colors='dark'] {
  --theme-background: #1b1b1b;  /*背景色*/
  --theme-menuBackground : #343434; /*菜单颜色*/
  --theme-menuIcon : #cdcdcd; /*菜单icon*/
  --theme-activeColor : #97a1fe;
}
/* 白天 */
html[theme-colors='white'] {
  --theme-background: #ecf5ff; /*背景色*/
  --theme-menuBackground : #fff; /*菜单颜色*/
  --theme-menuIcon : #303133; /*菜单icon*/
  --theme-activeColor : #97a1fe;
}

默认情况用:root定义的样式,黑夜模式用dark,白天用white

公共样变量定义后,我们就可以到页面使用了,例如设置卡片的背景色:

.card {
  background: var(--theme-background); 
}

此时访问的是:root中的默认变量,我们需要做到根据按钮切换,访问不同主题下的变量

<!-- 换肤 -->
<el-switch
    v-model="theme"
    inline-prompt
    style="--el-switch-on-color: #13ce66; --el-switch-off-color: #97a0ff"
    :active-icon="Sunny"
    :inactive-icon="Moon"
    @change="themeChange"
/>
// 主题切换
const theme = ref<boolean>(true);
const themeChange = (val : boolean) => {
  // true白天 false夜晚
   if(val){
    document.querySelectorAll('html')[0].setAttribute('theme-colors','white')
   } else {
    document.querySelectorAll('html')[0].setAttribute('theme-colors','dark')
   }
}

setAttribute()设置指定元素上的某个属性值。如果属性已经存在,则更新该值;否则,使用指定的名称和值添加一个新的属性。如果要切换夜间模式,我们可以给html设置一个属性为theme-colors = dark,此时我们就可以访问html[theme-colors='dark']下的css变量了

,白天模式切换theme-colors = white即可。

在做项目之前我们可以考虑到这一点,否则后期页面都写好了再改会比较麻烦。如果用了前端框架的话,我们需要覆盖框架自带的样式,我们可以将覆盖的样式写成公共文件,全局引入或者在对应页面引入即可。


如果觉得这篇文章对你有帮助,欢迎点赞👍、收藏💖、转发✨哦~

目录
相关文章
|
13天前
|
前端开发 JavaScript 搜索推荐
前端小白也能学会的高大上技巧:如何让你的网页支持暗黑模式?
【10月更文挑战第30天】随着现代网页设计的发展,暗黑模式已成为一种流行趋势,提升了用户的阅读体验并增强了网页的适应性。本文介绍了如何通过简单的HTML、CSS和JavaScript实现网页的暗黑模式。首先,定义两种主题的CSS样式;然后,使用JavaScript实现模式切换逻辑,并自动检测系统主题。通过这些步骤,前端小白也能轻松掌握暗黑模式的实现,提升网页的用户体验和个性化水平。
33 4
|
3月前
|
开发者 编解码
界面适应奥秘:从自适应布局到图片管理,Xamarin响应式设计全解析
【8月更文挑战第31天】在 Xamarin 的世界里,构建灵活且适应性强的界面是每位开发者的必修课。本文将带您探索 Xamarin 的响应式设计技巧,包括自适应布局、设备服务协商和高效图片管理,帮助您的应用在各种设备上表现出色。通过 Grid 和 StackLayout 实现弹性空间分配,利用 Device 类检测设备类型以加载最优布局,以及使用 Image 控件自动选择合适图片资源,让您轻松应对不同屏幕尺寸的挑战。掌握这些技巧,让您的应用在多变的市场中持续领先。
39 0
|
6月前
|
前端开发 算法
【css炫酷动画】让面试官眼前一亮的故障风格文字动画,3年Web前端开发工程师面试经验分享
【css炫酷动画】让面试官眼前一亮的故障风格文字动画,3年Web前端开发工程师面试经验分享
|
移动开发 前端开发 JavaScript
入坑吗?说说几个富文本编辑器
入坑吗?说说几个富文本编辑器
50 1
|
存储 设计模式 XML
QMUI实战(四)— QMUI 换肤的实现
QMUI 2 一个最大的特色就是支持了换肤(夜间模式),今天就来聊聊 QMUI 换肤的使用与实现。
961 0
|
存储 前端开发 搜索推荐
前端 “一键换肤“ 的几种方案
前端 “一键换肤“ 的几种方案
251 0
|
小程序 JavaScript 前端开发
微信小程序 | 酷炫时钟样式整理【附源码】
微信小程序 | 酷炫时钟样式整理【附源码】
529 0
微信小程序 | 酷炫时钟样式整理【附源码】
|
缓存 前端开发 JavaScript
换肤 - 一文看破常用的网站主题切换方式
现在大部分主流网站都不约而同的添加了暗色主题,让我们一起看看这些常用的切换方案、实现方式以及注意点。
|
前端开发
前端工作总结174-富文本编辑器使用篇wangedit
前端工作总结174-富文本编辑器使用篇wangedit
387 0
前端工作总结174-富文本编辑器使用篇wangedit
|
前端开发
前端工作总结145-页面布局
前端工作总结145-页面布局
85 0
前端工作总结145-页面布局