分类
JavaScript黑夜主题切换实现方案
利用CSS变量与类名切换,结合本地存储与系统偏好,实现平滑过渡的夜间模式
前端基础
2026-06-18
10

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

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')
目录
统计
21
分类
12
文档
1
坚持