App.vue 848 B

12345678910111213141516171819202122232425262728293031323334
  1. <template>
  2. <ElConfigProvider size="default" :locale="locales[language]" :z-index="3000">
  3. <RouterView></RouterView>
  4. </ElConfigProvider>
  5. </template>
  6. <script setup lang="ts">
  7. import { useUserStore } from './store/modules/user'
  8. import zh from 'element-plus/es/locale/lang/zh-cn'
  9. import en from 'element-plus/es/locale/lang/en'
  10. import { setThemeTransitionClass } from './utils/theme/animation'
  11. import { checkStorageCompatibility } from './utils/storage'
  12. const userStore = useUserStore()
  13. const { language } = storeToRefs(userStore)
  14. const locales = {
  15. zh: zh,
  16. en: en
  17. }
  18. onBeforeMount(() => {
  19. setThemeTransitionClass(true)
  20. })
  21. onMounted(() => {
  22. // 检查存储兼容性
  23. checkStorageCompatibility()
  24. // 提升暗黑主题下页面刷新视觉体验
  25. setThemeTransitionClass(false)
  26. })
  27. </script>