# 默认主题修改为浅色模式 - 设计文档 **日期:** 2026-03-06 **状态:** 已批准 **作者:** Claude Code ## 1. 概述 ### 1.1 背景 当前系统默认使用深色模式侧边栏(`theme-dark`),需要将默认主题修改为浅色模式(`theme-light`)。 ### 1.2 目标 - 将新用户的默认主题从深色模式改为浅色模式 - 保持老用户的自定义设置不受影响 - 确保主题切换功能完全正常 ### 1.3 范围 - 仅修改前端默认配置 - 不涉及后端修改 - 不涉及数据库修改 ## 2. 当前架构 ### 2.1 主题配置层级 ``` settings.js (默认配置) ↓ store/modules/settings.js (Vuex 状态管理) ↓ layout/components/Settings/index.vue (用户界面设置) ↓ localStorage (持久化用户设置) ``` ### 2.2 主题初始化逻辑 **文件:** `ruoyi-ui/src/store/modules/settings.js` ```javascript const storageSetting = JSON.parse(localStorage.getItem('layout-setting')) || '' const state = { sideTheme: storageSetting.sideTheme || sideTheme, // localStorage 优先 // ... } ``` **逻辑:** 1. 从 `settings.js` 读取默认值 2. 检查 `localStorage` 是否有用户设置 3. 如果有用户设置,使用用户设置覆盖默认值 4. 如果没有用户设置,使用默认值 ## 3. 设计方案 ### 3.1 修改内容 **文件:** `ruoyi-ui/src/settings.js` **变更:** 第 9 行 ```javascript // 修改前 sideTheme: 'theme-dark', // 修改后 sideTheme: 'theme-light', ``` ### 3.2 数据流 #### 新用户首次访问 ``` 用户访问系统 ↓ store/modules/settings.js 初始化 ↓ 读取 settings.js: sideTheme = 'theme-light' ↓ 检查 localStorage: 为空 ↓ 使用默认值: 'theme-light' ↓ 渲染浅色模式侧边栏 ``` #### 老用户访问(已保存设置) ``` 用户访问系统 ↓ store/modules/settings.js 初始化 ↓ 读取 settings.js: sideTheme = 'theme-light' ↓ 检查 localStorage: 有值 { sideTheme: 'theme-dark' } ↓ 使用 localStorage 中的值: 'theme-dark' ↓ 渲染深色模式侧边栏(保持用户设置) ``` ### 3.3 兼容性 **向后兼容:** - ✅ 老用户的 localStorage 设置不受影响 - ✅ 老用户看到的主题与之前一致 **向前兼容:** - ✅ 新用户默认看到浅色模式 - ✅ 用户仍可自由切换主题 - ✅ 保存/重置功能完全正常 ## 4. 影响分析 ### 4.1 影响范围 **文件变更:** - `ruoyi-ui/src/settings.js`(1 行代码) **功能影响:** - ✅ 无功能变更 - ✅ 无接口变更 - ✅ 无数据结构变更 ### 4.2 用户体验影响 **新用户:** - 从深色模式默认值 → 浅色模式默认值 **老用户:** - 无影响(localStorage 中的设置优先) ## 5. 测试计划 ### 5.1 测试用例 | 测试场景 | 操作步骤 | 预期结果 | |---------|---------|---------| | 新用户首次访问 | 1. 清除 localStorage
2. 刷新页面 | 侧边栏为浅色模式 | | 老用户(深色模式) | 1. localStorage 保存深色模式
2. 刷新页面 | 侧边栏仍为深色模式 | | 老用户(浅色模式) | 1. localStorage 保存浅色模式
2. 刷新页面 | 侧边栏仍为浅色模式 | | 切换主题 | 1. 打开设置抽屉
2. 点击深色/浅色图标 | 侧边栏立即切换 | | 保存设置 | 1. 切换主题
2. 点击"保存配置"
3. 刷新页面 | 设置保持不变 | | 重置设置 | 1. 修改多个设置
2. 点击"重置配置" | 恢复为默认值(浅色模式) | ### 5.2 浏览器兼容性 测试浏览器: - ✅ Chrome (最新版) - ✅ Firefox (最新版) - ✅ Edge (最新版) - ✅ Safari (最新版) ## 6. 部署方案 ### 6.1 部署步骤 1. **修改代码** ```bash # 修改 ruoyi-ui/src/settings.js ``` 2. **提交代码** ```bash git add ruoyi-ui/src/settings.js git commit -m "feat: 将默认主题修改为浅色模式" ``` 3. **构建前端** ```bash cd ruoyi-ui npm run build:prod ``` 4. **部署静态资源** - 将 `ruoyi-ui/dist/` 目录部署到生产服务器 5. **验证部署** - 清除浏览器缓存 - 访问系统 - 验证新用户看到浅色模式 ### 6.2 回滚方案 如果发现问题,可快速回滚: ```javascript // settings.js 第 9 行 sideTheme: 'theme-dark', // 改回深色模式 ``` 然后重新构建和部署。 ## 7. 风险评估 ### 7.1 风险列表 | 风险 | 概率 | 影响 | 缓解措施 | |-----|------|------|---------| | 老用户困惑 | 低 | 低 | 老用户设置不受影响 | | 浅色模式样式问题 | 低 | 中 | 需要充分测试 | | 部署失败 | 低 | 高 | 准备回滚方案 | ### 7.2 总体风险 **风险等级:** 低 **理由:** - 仅修改一行配置代码 - 不影响老用户设置 - 可以快速回滚 ## 8. 验收标准 ### 8.1 功能验收 - ✅ 新用户首次访问看到浅色模式侧边栏 - ✅ 老用户的自定义主题设置保持不变 - ✅ 主题切换功能正常 - ✅ 主题保存功能正常 - ✅ 主题重置功能正常 ### 8.2 质量验收 - ✅ 代码审查通过 - ✅ 测试用例全部通过 - ✅ 无控制台错误 - ✅ 浏览器兼容性测试通过 ## 9. 后续优化建议 ### 9.1 短期优化 - 可以考虑在设置界面添加"推荐"标签,标注浅色模式 - 可以考虑在首次登录时提示用户可以自定义主题 ### 9.2 长期优化 - 可以考虑添加更多预设主题(护眼模式、高对比度模式等) - 可以考虑将主题设置保存到后端数据库,实现跨设备同步 ## 10. 附录 ### 10.1 相关文件 - `ruoyi-ui/src/settings.js` - 默认配置文件 - `ruoyi-ui/src/store/modules/settings.js` - Vuex 状态管理 - `ruoyi-ui/src/layout/components/Settings/index.vue` - 设置界面组件 - `ruoyi-ui/src/components/ThemePicker/index.vue` - 主题颜色选择器 ### 10.2 参考资料 - [Element UI 主题定制](https://element.eleme.cn/#/zh-CN/theme) - [Vuex 状态管理](https://vuex.vuejs.org/zh/)