网站夜间模式是怎样实现的?

网站夜间模式的实现思路与详细教程分享

整体思路

夜间模式开关按钮:用来手动切换夜间模式的,会存储cookie。
自动夜间模式:当cookie为空时,浏览器时间大于22点小于6点时会自动进入夜间模式,并存储cookie。
后端配合:php判断是否有cookie,有的话直接输出夜间css,避免切换页面时网页闪烁。

具体操作

引入黑夜 css

<link href="dark.css" rel="alternate stylesheet" type="text/css" title="dark">

有title熟悉rel属性值同时包含alternate stylesheet的<link>作为备选样式CSS文件加载,默认不渲染。

切换夜间模式的 js 函数

  1. function switchNightMode(){
  2. var night = document.cookie.replace(/(?:(?:^|.*;\s*)night\s*\=\s*([^;]*).*$)|^.*$/, "$1") || '0';
  3. if(night == '0'){
  4. document.querySelector('link[title="dark"]').disabled = true;
  5. document.querySelector('link[title="dark"]').disabled = false;
  6. document.cookie = "night=1;path=/"
  7. console.log('夜间模式开启');
  8. }else{
  9. document.querySelector('link[title="dark"]').disabled = true;
  10. document.cookie = "night=0;path=/"
  11. console.log('夜间模式关闭');
  12. }
  13. }

指定时间进入夜间模式

  1. (function(){
  2. if(document.cookie.replace(/(?:(?:^|.*;\s*)night\s*\=\s*([^;]*).*$)|^.*$/, "$1") === ''){
  3. if(new Date().getHours() > 22 || new Date().getHours() < 6){
  4. document.querySelector('link[title="dark"]').disabled = true;
  5. document.querySelector('link[title="dark"]').disabled = false;
  6. document.cookie = "night=1;path=/"
  7. console.log('夜间模式开启');
  8. }else{
  9. document.cookie = "night=0;path=/"
  10. console.log('夜间模式关闭');
  11. }
  12. }else{
  13. var night = document.cookie.replace(/(?:(?:^|.*;\s*)night\s*\=\s*([^;]*).*$)|^.*$/, "$1") || '0';
  14. if(night == '0'){
  15. document.querySelector('link[title="dark"]').disabled = true;
  16. console.log('夜间模式关闭');
  17. }else if(night == '1'){
  18. document.querySelector('link[title="dark"]').disabled = true;
  19. document.querySelector('link[title="dark"]').disabled = false;
  20. console.log('夜间模式开启');
  21.  
  22. }
  23. }
  24. })();

php 后端判断 cookie 进行加载 css

  1. <link href="dark.css" rel="<?php if($_COOKIE['night'] != '1'){echo 'alternate ';} ?>stylesheet" type="text/css" title="dark">

本文已通过「原本」原创作品认证,转载请注明文章出处及链接。

夏日阳光
  • 本文由 夏日阳光 发表于 2020年11月13日
  • 本文为夏日阳光原创文章,转载请务必保留本文链接:https://www.pieruo.com/158.html
匿名

发表评论

匿名网友
:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:
确定

拖动滑块以完成验证
加载中...