您现在的位置是:网站首页> 编程资料编程资料
详解如何简单实现CSS主题的切换基于Css Variable的主题切换完美解决方案(推荐)CSS变量实现主题切换的方法
2021-09-03
866人已围观
简介 这篇文章主要介绍了详解如何简单实现CSS主题的切换,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
我最近在我的个人网站上添加了一个非常简单的配色方案(主题)切换器。您可以在网站的页脚中切换此简单的颜色切换器,以查看其实际效果。万一其他人希望将这样的功能添加到自己的站点/项目中,我想我会写一篇简短的文章解释如何做。让我们开始吧。

HTML
首先,我们需要包含“按钮”,这些按钮将触发主题根据选择的主题进行切换。(注:你总是可以使这些作为 options 一个 select 元素,如果你最好的方法)
而已!现在不必太担心 onclick 参数,我们将在添加JavaScript时再回到这一点。剩下的唯一一项是向 html 元素添加默认主题类,如下所示:
CSS
接下来,我们需要为两个 color-select 按钮设置样式,并使用将更改整个网站的自定义配色方案。我们将从配色方案开始。
为了使这些主题之间能够无缝切换,我们将更改的颜色集设置为CSS变量:
.theme-default { --accent-color: #72f1b8; --font-color: #34294f; } .theme-second { --accent-color: #FFBF00; --font-color: #59316B; } .theme-third { --accent-color: #d9455f; --font-color: #303960; } body { background-color: var(--accent-color); color: var(--font-color); }最后,我们设置面向用户的色板的样式:
.color-select button { -moz-appearance: none; appearance: none; border: 2px solid; border-radius: 9999px; cursor: pointer; height: 20px; margin: 0 0.8rem 0.8rem 0; outline: 0; width: 20px; } /* Style each swatch to match the corresponding theme */ .color-select button:nth-child(1) { background: #72f1b8; border-color: #34294f; } .color-select button:nth-child(2) { background: #FFBF00; border-color: #59316B; } .color-select button:nth-child(3) { background: #d9455f; border-color: #303960; }JavaScript
我们需要使每个色样按钮触发其相应的主题,并交换出 theme-default 我们最初附加到主 html 元素上的类。我们还需要存储用户选择的内容 localStorage ,因此在重新加载或导航到其他页面时,他们的选择仍然存在。
// Set a given theme/color-scheme function setTheme(themeName) { localStorage.setItem('theme', themeName); document.documentElement.className = themeName; } // Toggle between color themes function toggleDefaultTheme() { if (localStorage.getItem('theme') !== 'theme-default'){ setTheme('theme-default'); } } function toggleSecondTheme() { if (localStorage.getItem('theme') !== 'theme-second'){ setTheme('theme-second'); } } function toggleThirdTheme() { if (localStorage.getItem('theme') !== 'theme-third'){ setTheme('theme-third'); } } // Immediately set the theme on initial load (function () { if (localStorage.getItem('theme') === 'theme-default') { setTheme('theme-default'); } if (localStorage.getItem('theme') === 'theme-second') { setTheme('theme-second'); } if (localStorage.getItem('theme') === 'theme-third') { setTheme('theme-third'); } })();就是这样!现在,这仅取决于您希望每种主题样式的自定义程度。可能性是无止境!
到此这篇关于详解如何简单实现CSS主题的切换的文章就介绍到这了,更多相关CSS主题的切换内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
相关内容
- CSS3+JavaScript实现炫酷呼吸效果的示例代码使用CSS媒体查询(Media Queries)和JavaScript判断浏览器设备类型的方法使用html5+css3来实现slider切换效果告别javascript+css
- 纯CSS实现左右拖拽改变布局大小纯 CSS 实现拖拽效果的代码
- div自适应高度自动填充剩余高度div不能自适应高度不能随图片的高度变化拥有最小高度能自适应高度同时全兼容IE、FF的div设置子元素div高度不确定时父div高度如何自适应相邻div实现一个跟着另一个自适应高度示例代码怎样让一个div高度自适应浏览器高度CSS min-height IE6、IE7、FF下DIV自适应高度
- CSS让子容器超出父元素(子容器悬浮在父容器效果)css使用flexbox布局容器内多元素水平居中Css浮动元素外层容器高度为0(无高度)的解决方法CSS常见的让元素水平居中显示的方法清除网页浮动CSS的做法CSS教程:彻底弄懂闭合浮动元素
- css3实现小箭头各种图形效果css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- 奇妙的 CSS 属性 MASK详解css中filter属性和backdrop-filter的应用与区别详解详解HTML5中CSS外观属性CSS中简写属性要注意TRouBLe的顺序问题(避免踩坑)CSS字体、文本、列表属性详细介绍CSS 继承 inherit属性的方法利用CSS中的 outline-offset 属性实现加号css一些不常见但很有用的属性操作大全
- 使用CSS cross-fade()实现背景图像半透明效果的示例代码
- 解决CSS样式冲突的几个办法(小结)css样式冲突问题练习示例
- CSS 中使用径向渐变实现卡券效果CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- CSS3里box-shadow属性的使用方法示例详解CSS3 box-shadow属性实例详解CSS3阴影效果样式库box-shadows.css 53种css3 box-shadow阴影(外阴影与外发光)图示讲解详解CSS3阴影 box-shadow的使用和技巧总结 CSS3实现多重边框的方法总结详解CSS3的box-shadow属性制作边框阴影效果的方法
