当前位置: 首页 > article >正文

html主题切换小demo

主题切换功能为网页和应用程序提供了多样化的视觉风格与使用体验。实现多主题切换的技术方案丰富多样,其中 CSS 变量和 JavaScript 样式控制是较为常见的实现方式。

以下是一个简洁的多主题切换示例,愿它能为您的编程之旅增添一份趣味。

代码展示

<!DOCTYPE html>
<html lang="zh">
<head><meta charset="UTF-8"><title>多主题切换 Demo</title><style>:root {--bg-color: #ffffff;--text-color: #000000;}body {background-color: var(--bg-color);color: var(--text-color);font-family: sans-serif; /* 字体 */text-align: center; /* 居中对齐 */transition: background-color 0.3s, color 0.3s; /* 过渡效果 */padding-top: 100px; /* 顶部内边距 */}.dark-theme { /* 暗黑主题 */--bg-color: #121212;  /* 背景色 */--text-color: #eeeeee; /* 文字色 */}.blue-theme { /* 蓝色主题 */--bg-color: #e3f2fd;--text-color: #1565c0;}.green-theme { /* 绿色主题 */--bg-color: #e8f5e9;--text-color: #2e7d32;}.red-theme { --bg-color: #ffebee; --text-color: #c62828; }.purple-theme { --bg-color: #f3e5f5; --text-color: #6a1b9a; }.orange-theme { --bg-color: #fff3e0; --text-color: #ef6c00; }.gray-theme { --bg-color: #f5f5f5; --text-color: #424242; }select, button {padding: 10px 20px;font-size: 16px;margin-top: 20px;cursor: pointer;}</style>
</head>
<body><h1>选择主题</h1><p>这是个主题是 <span id="currentTheme">默认</span></p><select id="themeSelector" onchange="changeTheme()"><option value="">默认</option><option value="dark-theme">暗黑</option><option value="blue-theme">蓝色</option><option value="green-theme">绿色</option><option value="red-theme">红色</option><option value="purple-theme">紫色</option><option value="orange-theme">橙色</option><option value="gray-theme">灰色</option></select><script>function changeTheme() {const theme = document.getElementById('themeSelector').value;document.body.className = theme;const themeName = theme ? theme.split('-')[0] : '默认';document.getElementById('currentTheme').textContent = themeName;}</script>
</body>
</html>

效果展示

实现原理解析

该 demo 的核心思想是通过 CSS标签引入不同的样式,并使用 JavaScript 修改其 href 属性,从而实现动态更换主题的功能。这种方式简单直观,适用于中小型项目或学习用途。

扩展建议

如果你希望进一步优化这个功能,可以考虑以下几点:

  • 使用 localStorage 记住用户选择的主题;

  • 使用 CSS 变量搭配类名控制,减少重复代码;

  • 使用框架(如 Vue/React)时结合组件化设计进行封装;

  • 添加动画过渡效果,提升用户体验。

http://www.lryc.cn/news/2384414.html

相关文章:

  • AI架构职责分配——支持AI模块的职责边界设计
  • git@gitee.com: Permission denied (publickey). fatal: 无法读取远程仓库
  • CARIS HIPS and SIPS 12.1是专业的多波束水深数据和声呐图像处理软件
  • Docker端口映射与容器互联
  • 在 Ubuntu 24.04 LTS 上 Docker 部署 DB-GPT
  • 使用 Docker 搭建 PyWPS 2.0 服务全流程详解
  • Axure高保真CRM客户关系管理系统原型
  • 自学嵌入式 day 23 - 数据结构 树状结构 哈希表
  • JavaScript进阶(十二)
  • Honeywell CV-DINA-DI1624-2A 数字输入模块
  • 中文域名25周年,取得哪些里程碑式的进展?
  • HTTP协议接口三种测试方法之-postman
  • 【Linux cmd】查看 CPU 使用率的几个命令
  • 架空线路监控系统是针对高压架空输电线路设计的一种安全监测解决方案
  • Kotlin Compose Button 实现长按监听并实现动画效果
  • 应对进行性核上性麻痹,健康护理铸就温暖防线
  • python邮件地址检验 2024年信息素养大赛复赛/决赛真题 小学组/初中组 python编程挑战赛 真题详细解析
  • CAD球体功能梯度材料3D插件
  • 自制操作系统day9内存管理(cache、位图、列表管理、内存的释放)(ai辅助整理)
  • JavaWebsocket-demo
  • 特征学习:赋予机器学习 “慧眼” 的核心技术
  • 3D个人简历网站 7.联系我
  • 软考中级软件设计师——计算机系统篇
  • 甘特图(项目计划图)
  • Java流式处理-Steam详解
  • windows服务器部署jenkins工具(一)
  • LCS4110R加密芯片在打印机墨盒的应用
  • 什么是 API 管理?为什么管理 API 很重要?如何用 iPaaS 平台管理 API
  • 基于51单片机和8X8点阵屏、独立按键的飞行躲闪类小游戏
  • 告别“盘丝洞”车间:4-20mA无线传输如何重构工厂神经网?