博文上次更新时间
2025-09-28 14:54:31
日夜间模式切换功能
摘要:实现日夜间模式切换功能。
源码详见_sass\_daynight.scss
,assets\main.scss
,_includes\header.html
,_includes\head.html
,_includes\daynight.html
。
仓库地址:n1uf的github
功能实现:
- 使用了
_daynight.scss
创建样式(注意!important
覆盖原有高光样式)。 header.html
中引用样式(在页头的尾部添加)。daynight.html
中写入按钮的点击触发js
,并引用在header.html
中。- 在主SCSS文件
main.scss
中导入新样式(@import "daynight";
)。
一些优化:
-
蓝色链接在夜间模式显示不清晰问题:添加了
css
中a
样式的夜间模式颜色适配,并为title
等类型加了!important
标签以防也被处理。 - 关于夜间模式下,该网站切换页面时的由日间模式变为夜间模式所带来的闪烁现象的修复。
-
在页面加载前应用夜间模式。
通过在页面加载之前检查本地存储中的主题设置,并将夜间模式样式直接应用到
<body>
标签。可以在<head>
内加入一段内联脚本:在
head.html
的<head>
标签中添加以下脚本,确保它在任何 CSS 加载之前执行:<script> (function() { const currentTheme = localStorage.getItem('theme'); if (currentTheme === 'night') { document.documentElement.classList.add('night-mode'); } })(); </script>
-
使用
html
或body
的类优先设置。为防止页面加载时样式抖动,在 SCSS 中使用默认样式或带有
.night-mode
的选择器。例如,在_daynight.scss
中:body { transition: background-color 0.3s ease, color 0.3s ease; } body.night-mode { background-color: #2a2a2a; color: #ffffff; } // 为页面加载前默认添加无动画样式 html.night-mode body { transition: none; // 避免加载时初始闪烁 }
-
延迟显示页面内容。
如果仍有细微闪烁,可以通过设置页面加载时的隐藏效果来解决。在
head.html
中添加:<style> body { visibility: hidden; } </style>
然后在加载完成后恢复显示,改良
DOMContentLoaded
的 JS:document.addEventListener('DOMContentLoaded', () => { document.body.style.visibility = 'visible'; });
通过这几个步骤,夜间模式切换功能可以更平滑且没有明显的闪烁问题。推荐优先使用在页面加载前通过类名应用夜间模式的方式。
-
-
修好闪烁后发现,原先的0.3s的日夜间过渡没有了,于是修这个没有过渡的BUG,方法为加载完成后恢复动画过渡。
-
修改
_daynight.scss
添加一个初始禁用过渡的样式:
body { transition: none; // 初始禁用过渡 } body.transition-enabled { transition: background-color 0.3s ease, color 0.3s ease; } body.night-mode { background-color: #2a2a2a; color: #ffffff; }
-
修改
daynight.html
中的脚本在
DOMContentLoaded
时为body
添加transition-enabled
类:document.addEventListener('DOMContentLoaded', () => { document.body.style.visibility = 'visible'; const toggleButton = document.getElementById("toggleButton"); const body = document.body; // 检查本地存储中的主题设置 const currentTheme = localStorage.getItem('theme'); if (currentTheme === 'night') { body.classList.add('night-mode'); toggleButton.textContent = "切换到日间模式"; } // 页面加载后添加 transition 类,恢复过渡动画 setTimeout(() => { body.classList.add('transition-enabled'); }, 100); // 延迟避免初始加载的过渡 // 切换按钮点击事件 toggleButton.addEventListener("click", () => { if (body.classList.toggle("night-mode")) { toggleButton.textContent = "切换到日间模式"; localStorage.setItem('theme', 'night'); } else { toggleButton.textContent = "切换到夜间模式"; localStorage.setItem('theme', 'day'); } }); });
通过首次加载禁用过渡,之后使用按钮改变时应用过渡的方式修掉了这个BUG。
-
-
移动端 header 尾部的导航栏 site-nav 没有应用为夜间模式。
在
daynight.scss
的body.night-mode
中添加.site-nav
夜间样式。