logo 范 · 拾光录
网址收集 关于作者 Github Gitee
杂文随笔5
Hexo博客:基础使用Hexo博客:Next主题Hexo博客:Next进阶使用Hexo博客:Next高级配置基于Node的WIKI管理
前端知识16
HTML常用知识CSS常用知识CSS美化checkbox复选框JavaScript常用知识JavaScript格式化时间戳JavaScript窗口宽高处理JavaScript黑夜主题切换实现方案JavaScript数字转大写简易图片查看器TypeScript基础知识Threejs基础三要素Threejs网格辅助和轨道控制器Threejs物体绘制Electron基础使用Nodejs基础知识animate.css页面动画
Vue框架2
Vite的使用及扩展Vue3父子组件

随着夜间模式切换的出现,很多软件和主题都开始对夜间模式进行支持,以给用户带来更好的使用体验,而对于网页端而言,实现夜间模式的切换方法很多

CSS变量的使用

:root {
    --background-color: #fff
}

.dark {
    --background-color: #23272e
}

定义好CSS变量后,将使用颜色的地方更改为var(--background-color),这样全局会使用root中的变量,而加了class="dark"的地方会使用dark的变量,也就实现了颜色的定义

切换方法

// 添加
document.querySelector('body').classList.add("dark")
// 移除
document.querySelector('body').classList.remove("dark")

更改root中的变量

如果变量不再定义的dark中,例如滚动条的轨道颜色,就需要直接更改root中的变量,方法为

document.documentElement.style.setProperty('--scroll-bg-color-custom', '#2c313a')
CSS变量的使用
切换方法
更改root中的变量