Typecho主题白天夜晚模式切换失效怎么办?

霞舞
发布: 2025-02-25 08:04:01
原创
721人浏览过

typecho主题白天夜晚模式切换失效?刷新后模式丢失?

Typecho主题白天夜晚模式切换失效怎么办?

许多Typecho用户在尝试添加白天/夜晚模式切换功能后,发现切换效果无法持久,刷新页面后设置便会失效。本文提供解决方案,帮助您解决此问题。

问题描述:

按照网上教程添加白天夜晚模式切换代码到footer.php后,刷新或点击链接,模式设置无法保存。

解决方案:

此问题通常是由于没有正确保存模式设置到浏览器Cookie导致的。以下步骤将引导您修复此问题:

  1. 修改footer.php: 在footer.php底部添加以下JavaScript代码,用于读取和设置Cookie:
window.onload = function() {
  let mode = getCookie('read-mode');
  if (mode === 'night') {
    document.body.classList.add('night-mode');
  } else {
    document.body.classList.remove('night-mode');
  }
};

function setCookie(name, value, days) {
  let expires = '';
  if (days) {
    let date = new Date();
    date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
    expires = '; expires=' + date.toUTCString();
  }
  document.cookie = name + '=' + (value || '') + expires + '; path=/';
}

function getCookie(name) {
  let nameEQ = name + '=';
  let ca = document.cookie.split(';');
  for (let i = 0; i < ca.length; i++) {
    let c = ca[i];
    while (c.charAt(0) === ' ') c = c.substring(1, c.length);
    if (c.indexOf(nameEQ) === 0) return c.substring(nameEQ.length, c.length);
  }
  return null;
}

//  添加切换模式的事件监听器 (假设您已有切换按钮,并使用id="mode-switch")
document.getElementById('mode-switch').addEventListener('click', function() {
  let currentMode = getCookie('read-mode');
  let newMode = currentMode === 'night' ? '' : 'night';
  setCookie('read-mode', newMode, 365); // 设置Cookie,有效期为一年
  location.reload(); // 刷新页面以应用新的模式
});
登录后复制
  1. 修改function.php: 修改function.php中的getReadMode()函数,使其能够正确处理Cookie:
function getReadMode($icon = false) {
    $class = isset($_COOKIE['read-mode']) ? $_COOKIE['read-mode'] : ''; // 获取cookie,如果不存在则为空字符串
    if ($icon) {
        $class = $class === 'night' ? 'fa fa-moon-o' : 'fa fa-sun-o';
    } else {
        $class = $class === 'night' ? 'night-mode' : '';
    }
    echo $class;
}
登录后复制

请确保您的主题CSS文件中定义了.night-mode类,用于控制夜晚模式的样式。 上述代码添加了setCookie函数用于设置cookie,并修改了getReadMode函数使其更健壮,并添加了页面刷新,以立即反映模式变化。 最后,添加了一个事件监听器示例,假设您有一个id为mode-switch的按钮来切换模式。 请根据您的实际情况调整代码。

通过以上修改,您的Typecho主题白天夜晚模式切换功能应该能够正常工作并保持设置了。 如果问题仍然存在,请检查您的主题代码,确保night-mode类应用正确,并且JavaScript代码正确地插入到footer.php中。

以上就是Typecho主题白天夜晚模式切换失效怎么办?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号