Tailwindcss开启黑夜模式

本篇讲述如何使用tailwindcss切换白天黑夜主题

tailwindcss自带的暗夜切换会比css自带的theme主体切换来得方便很多,学习成本也很低,只要求会用tailiwndcss

1,tailwindcss.config有两种暗夜模式切换,媒体查询和手动类切换。手动控制需要开启类模式

javascript 复制代码
// tailwind.config.js
export default {
    ...
    darkMode:'class', // 使用class策略
}

2,设置点击切换事件:点击为html根元素添加dark类

javascript 复制代码
// 切换主体颜色(直接修改html的类)
const toggleTheme = () => {
    const html = document.documentElement

    html.classList.toggle('dark')
    if (html.classList.contains('dark')) {
        localStorage.setItem('Dark', 'true')
    } else {
        localStorage.removeItem('Dark')
    }
}

切换后 将是否有dark类 存放在localstorage中,保持记忆性

3,进入网页前,记忆用户选择的模式,在index.html中写入函数,使其在页面渲染前执行,如果localstorage已经存放了dark 代表开启暗夜模式 如果没有 则不执行

javascript 复制代码
// index.html  
<head>
<script>
      // 在页面渲染前执行
      (function() {
        if (localStorage.getItem('Dark')) {
          document.documentElement.classList.add('dark');
        }
      })();
    </script>
</head>
相关推荐
金金金__25 分钟前
Element-Plus:popconfirm与tooltip一起使用不生效?
前端·vue.js·element
前端梭哈攻城狮35 分钟前
uniapp图片上传添加水印/压缩/剪裁
前端·javascript·vue.js
空&白1 小时前
css元素的after制作斜向的删除线
前端·css
奇舞精选2 小时前
你可能不知道但非常实用的 HTML5 元素
css
踢足球的,程序猿2 小时前
从 Vue 2.0 进阶到 Vue 3.0 的核心技术解析指南
前端·javascript·vue.js·前端框架·html
Jolyne_3 小时前
grid 实现完美的水平铺满、间隔一致的自适应布局
前端·css
西洼工作室3 小时前
【解决导航栏字体图标渲染导致文本闪烁问题】采用腾讯视频的解决方案
前端·css·css3
站在风口的猪11083 小时前
《前端面试题:CSS的display属性》
前端·css·html·css3·html5
掘金安东尼4 小时前
仅仅是发送一封邮件?暴露安全边界!
javascript·vue.js·面试
FogLetter4 小时前
从Flex布局到Transition艺术:打造让用户尖叫的前端体验
前端·css