AI取名大师 | uni-app + Wot UI 跟随设备自动切换明暗主题

关于 AI 取名大师

借助豆包通义千问DeepSeek 等 AI 大模型,为您的宝宝、宠物、店铺、网名、笔名、项目、产品、服务、文章等取一个专业、有意义的名字😄。


开源地址:👉GitCode(国内友好)👈、👉GitHub👈

技术组合:Bun.jsElysia.jsuni-app

体验地址:AI取名大师(H5版)

特别注明:本系列文章仅为实战经验分享,并记录开发过程中碰到的问题😄,如有不足之处欢迎随时留言提出。


📣 问题简述

运行程序时,偶尔会碰到明亮、暗黑主题错乱的问题(如下图),要么是背景 light 而组件 dark,或者是背景 dark 而组件 light,非常影响视觉效果😂。

🤔 原因分析

程序使用 pinia 状态库记录是否启用暗黑主题,参考的是 snail-uni 模板 的做法。

js 复制代码
export const useUIStore = defineStore('ui', {
    state:()=>({
        dark: false
    }),
    actions: {
        setDark (v){
            if(this.dark == v)  return

            this.dark = v
        }
    },
    unistorage: true
})

整体流程如下:

  1. 应用 onLaunch:通过 uni.onThemeChange 监听主题变更以更新状态库的 dark
  2. 页面根据dark的值设置明暗主题
  3. dark 值变动后页面也跟着变换主题

这看起来是很正常的一个逻辑,但是在以下情况就出问题了:

  1. 状态库dark的值是true
  2. 系统的外观为浅色
  3. 此时打开页面就会出现:背景浅色而组件深色😔
  4. 反之就是背景深色而组件浅色

究其原因就是页面加载时没有判断dark的值与当前系统外观是否一致。

🛠️ 修复

找到原因后,我们对症下药:页面加载后直接更新外观值,而不仅限于uni.onThemeChange

js 复制代码
// App.vue
<script setup>
    import { updateToken } from '@U'
    import { useUIStore, useDataStore } from '@/store'

    const uiStore = useUIStore()
    const dataStore = useDataStore()

    const updateTheme = ({ theme }) => {
        uiStore.setDark(theme == 'dark')
    }

    onLaunch(() => {
        const info = uni.getSystemInfoSync()
        let theme = info.osTheme || info.hostTheme
        updateTheme({ theme })

        uni.onThemeChange(updateTheme)
    })
</script>

在页面中使用:

html 复制代码
<template>
    <view :class="{ 'wot-theme-dark': uiStore.dark }" :style="style">
    </view>
</template>

<script setup>
		import { useUIStore } from '@/store'
		const uiStore = useUIStore()
</script>

❓ 扩展思考

经过上面的调整,能够实现随系统自动切换外观配色,那有没有可能由用户自己选择吗?

目前还没有想到好的解决办法,因为出现应用与系统外观不一致的话,就会复现上面的问题😔。我观察了下,主流的 uni-app 模板也都是跟随系统。

如果各路大神有好的思路请留言😄。

相关推荐
AI效率工坊2 分钟前
【Python实战】自动化生成PPT演示文稿:python-pptx+AI内容生成+图表嵌入
人工智能·python·自动化
墨染天姬2 分钟前
【AI】CRISP 提示词框架
人工智能
高洁014 分钟前
工业AI部署:模型量化与边缘设备部署实战
人工智能·深度学习·机器学习·数据挖掘·transformer
上海达策TECHSONIC4 分钟前
汽车零配件 SAP 转型数字化标杆 上海达策实施 SAP Business One 赋能汽车底盘转向领域
大数据·运维·人工智能·汽车·运维开发·制造
IT_陈寒6 分钟前
Vue这个响应式陷阱让我加了两天班
前端·人工智能·后端
泰恒9 分钟前
ChatGPT发展历程
人工智能·深度学习·yolo·机器学习·计算机视觉
Omics Pro11 分钟前
斯坦福:强化学习生物约束型虚拟细胞建模
人工智能·深度学习·算法·机器学习·计算机视觉·数据挖掘·数据分析
阿坤带你走近大数据14 分钟前
什么是数据挖掘
人工智能·数据挖掘
TechWayfarer14 分钟前
RSAC 2026启示录:从IP归属到IP风险画像,风控系统如何防御住宅代理与AI攻击?
网络·人工智能·python·tcp/ip·ip
做个文艺程序员19 分钟前
Hermes Agent 技术深潜(三):记忆系统与学习循环的完整源码解析
人工智能