0

0

bootstrap怎么实现深色模式和浅色模式切换

畫卷琴夢

畫卷琴夢

发布时间:2026-03-18 16:13:03

|

895人浏览过

|

来源于php中文网

原创

Bootstrap 5.3+ 通过 data-bs-theme 属性支持深色/浅色模式切换,需手动实现按钮与 localStorage 持久化,并调用 bootstrap.Theme.getOrCreateInstance().update() 刷新 CSS 变量。

如何用 Bootstrap 5.3+ 原生支持切换深色/浅色模式

bootstrap 5.3 起内置了 data-bs-theme 属性和 prefers-color-scheme 自动适配,但**不自动提供切换按钮或状态持久化**——你得自己补上这两块。

核心逻辑是:改 <html><body>data-bs-theme 值为 "light""dark",再触发一次 Bootstrap 的内部主题刷新(靠 bootstrap.Theme 实例)。

  • 必须用 Bootstrap 5.3.0+,旧版本无 data-bs-theme 支持
  • <html data-bs-theme="light"> 是起点,不能只写在 <body>
  • 切换后需手动调用 bootstrap.Theme.getOrCreateInstance(document.documentElement).update(),否则 CSS 变量不会重算

切换按钮怎么写才不破坏 SSR 和初始渲染

服务端渲染(如 Next.js、SSR 模板)下,如果 JS 还没执行就按 data-bs-theme="dark" 渲染,用户会先看到闪屏(尤其深色背景+浅色文字)。解决方案是:初始 HTML 固定为 data-bs-theme="light",JS 加载后再根据用户偏好或 localStorage 补上真实值并更新。

  • 服务端永远输出 <html data-bs-theme="light">,不猜偏好
  • JS 加载后立即读 localStorage.getItem('theme')window.matchMedia('(prefers-color-scheme: dark)').matches
  • 设置完 document.documentElement.dataset.bsTheme 后,立刻调用 new bootstrap.Theme(document.documentElement).update()
  • 按钮本身建议用 <button type="button">,避免表单提交干扰

localStorage 存什么、什么时候存、为什么不能只存布尔值

存字符串 "light""dark",而不是 true/false。因为 Bootstrap 的 data-bs-theme 值是字符串,且后续扩展(比如加 "auto")需要明确语义。

Riffo
Riffo

Riffo是一个免费的文件智能命名和管理工具

下载
  • 每次点击切换按钮时,必须同步写入 localStorage.setItem('theme', 'dark')(或 'light'
  • 不要在 DOMContentLoaded 里读取后直接设 dataset.bsTheme 就结束——忘了调用 .update(),样式不会变
  • 若用户关闭浏览器又打开,仅靠 localStorage 恢复主题,prefers-color-scheme 不会自动触发,所以别依赖它做初始化

遇到 Uncaught TypeError: bootstrap.Theme is not a constructor 怎么办

这是最常卡住的地方:你用了 Bootstrap 的 ES 模块构建(bootstrap/dist/js/bootstrap.esm.js),但没正确导入 Theme 类,或者用了 CDN 的 UMD 版本(bootstrap.bundle.min.js)却试图直接访问 bootstrap.Theme

  • CDN 用户:必须用 https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/js/bootstrap.bundle.min.js(带 bundle),UMD 全局对象才有 bootstrap.Theme
  • ESM 用户:要显式导入 import { Theme } from 'bootstrap',不能从 bootstrap/dist/js/bootstrap.esm.js 直接解构
  • 检查控制台是否报 Failed to resolve module specifier "bootstrap"——路径错了,ESM 下必须用完整包名或相对路径

真正麻烦的不是切颜色,而是让切换在 SSR、缓存、多标签页之间保持一致;localStorage 写了但没调 .update(),或者用了 bundle 却当 ESM 用,这两个点几乎占了 80% 的失败案例。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python是前端还是后端
python是前端还是后端

Python属于前端也属于后端,其灵活性和丰富的生态系统使得开发人员能够在不同的领域中灵活运用。本专题为大家提供python相关的文章、下载、课程内容,供大家免费下载体验。

202

2023.08.11

前端如何实现即时通讯
前端如何实现即时通讯

实现即时通讯的方法有WebSocket、Long Polling、Server-Sent Events、WebRTC等等。详细介绍:1、WebSocket,它可以在客户端和服务器之间建立持久连接,实现实时的双向通信,前端可以使用 WebSocket API来创建WebSocket连接,并通过发送和接收消息来实现即时通讯;2、Long Polling,是一种模拟实时通信的技术等等。

275

2023.10.09

前端和后端的区别
前端和后端的区别

前端关注的是用户界面的设计和交互,而后端则注重数据处理和逻辑控制。想了解更多前端后端的相关内容,可以阅读本专题下面的文章。

413

2024.03.19

php和前端的关联介绍
php和前端的关联介绍

php既可以作为前端语言,也可以作为后端语言。想了解更多php和前端的相关内容,可以阅读本专题下面的文章。

233

2024.03.22

前端外包工作内容有哪些
前端外包工作内容有哪些

前端外包工作内容包括:1. 网站和应用程序开发;2. 用户界面和交互设计;3. 用户体验优化;4. 设计和视觉开发;5. 跨浏览器兼容性;6. 性能优化;7. 维护和更新;8. 项目管理和沟通。想了解更多前端的相关内容,可以阅读本专题下面的文章。

122

2024.05.22

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

5

2026.03.18

Java Spring Security权限控制与认证机制实战
Java Spring Security权限控制与认证机制实战

本专题围绕 Java 后端安全体系建设展开,重点讲解 Spring Security 在权限控制与认证机制中的应用实践。内容涵盖用户认证流程、权限模型设计、JWT 鉴权方案、OAuth2 集成以及接口安全防护策略。通过实际项目案例,帮助开发者构建安全可靠的后端认证体系,提升系统安全性与可扩展能力。

21

2026.03.18

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

137

2026.03.17

多环境下的 Nginx 安装、结构与运维实战
多环境下的 Nginx 安装、结构与运维实战

本专题聚焦多环境下Nginx实战,详解开发、测试及生产环境的差异化安装策略与目录结构规划。深入剖析配置模块化设计、灰度发布流程及跨环境同步机制。结合监控告警、故障排查与自动化运维工具,提供全链路管理方案,助力团队构建灵活、高可用的Nginx服务体系,从容应对复杂业务场景挑战。

14

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.7万人学习

HTML+CSS基础与实战
HTML+CSS基础与实战

共132课时 | 12.8万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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