Compare commits
	
		
			9 Commits
		
	
	
		
			8b144a270c
			...
			107966dabc
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 107966dabc | ||
|  | 88d1dea0d2 | ||
|  | 6fc63427de | ||
|  | 8cb35f4f1b | ||
|  | 579c6df57b | ||
|  | 0d1342414b | ||
|  | fbac90a177 | ||
|  | 44b593966e | ||
|  | 7ae4899e17 | 
| @ -1,6 +1,7 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import {useI18n} from 'vue-i18n' | import {useI18n} from 'vue-i18n' | ||||||
| 
 | import {message} from '@/components/x-message/useMessage.js' | ||||||
|  | // message.success('success') | ||||||
| useHead({ | useHead({ | ||||||
|   title: useI18n().t('appSetting.appName'), |   title: useI18n().t('appSetting.appName'), | ||||||
|   meta: [ |   meta: [ | ||||||
| @ -8,8 +9,9 @@ useHead({ | |||||||
|     {name: 'keywords', content: useI18n().t('appSetting.appKeyWords')}, |     {name: 'keywords', content: useI18n().t('appSetting.appKeyWords')}, | ||||||
|   ], |   ], | ||||||
| }) | }) | ||||||
|  | const color = useColorMode() | ||||||
| const mode = computed(() => { | const mode = computed(() => { | ||||||
|   return '' |   return color.value | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| // 添加路由中间件来处理过渡方向 | // 添加路由中间件来处理过渡方向 | ||||||
| @ -40,7 +42,7 @@ provide('slideDirection', slideDirection) | |||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <VanConfigProvider theme="light"> |   <VanConfigProvider :theme="mode"> | ||||||
|     <NuxtLoadingIndicator |     <NuxtLoadingIndicator | ||||||
|         color="repeating-linear-gradient(to right,var(--c-primary) 0%,var(--c-primary-active) 100%)"/> |         color="repeating-linear-gradient(to right,var(--c-primary) 0%,var(--c-primary-active) 100%)"/> | ||||||
|     <NuxtLayout> |     <NuxtLayout> | ||||||
| @ -76,6 +78,7 @@ provide('slideDirection', slideDirection) | |||||||
| .slide-right-leave-to { | .slide-right-leave-to { | ||||||
|   transform: translateX(100%); |   transform: translateX(100%); | ||||||
| } | } | ||||||
|  | 
 | ||||||
| :root { | :root { | ||||||
|   --safe-area-inset-bottom: env(safe-area-inset-bottom); |   --safe-area-inset-bottom: env(safe-area-inset-bottom); | ||||||
| } | } | ||||||
|  | |||||||
| @ -30,7 +30,9 @@ const subTitle = computed(() => { | |||||||
|   return route.meta.subTitle ? t(route.meta.subTitle) : '' |   return route.meta.subTitle ? t(route.meta.subTitle) : '' | ||||||
| }) | }) | ||||||
| const showLeftArrow = computed(() => route.name && routeWhiteList.includes(route.name)) | const showLeftArrow = computed(() => route.name && routeWhiteList.includes(route.name)) | ||||||
| 
 | console.log('route.meta.i18n',route.meta.i18n) | ||||||
|  | console.log('t(route.meta.i18n)',route.meta.i18n) | ||||||
|  | console.log('route.meta.title',route.meta.title) | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|  | |||||||
| @ -8,17 +8,7 @@ const props = defineProps({ | |||||||
|     default: null |     default: null | ||||||
|   } |   } | ||||||
| }) | }) | ||||||
| const images = [ | 
 | ||||||
|   'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/637d95b4-2ae9-4a74-bd60-a3a9d2ca2ca0.png', |  | ||||||
|   'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/f7b65e23-ce21-41b4-8e58-9e6dc6950727.png', |  | ||||||
|   'https://e-cdn.fontree.cn/fonchain-main/prod/file/default/setting/41eceb23-d168-4049-ae8e-48c5328b192f.png', |  | ||||||
| ]; |  | ||||||
| const clickSwipe=(index)=>{ |  | ||||||
|   showImagePreview({ |  | ||||||
|     images: images, |  | ||||||
|     startPosition:index, |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| @ -26,16 +16,6 @@ const clickSwipe=(index)=>{ | |||||||
|   <div class="flex justify-center"> |   <div class="flex justify-center"> | ||||||
|     <xImage class="h-188px" :src="detailInfo?.artwork?.hdPic"></xImage> |     <xImage class="h-188px" :src="detailInfo?.artwork?.hdPic"></xImage> | ||||||
|   </div> |   </div> | ||||||
| <!--  <van-swipe style="height: 188px" indicator-color="#B4B4B4"   lazy-render > |  | ||||||
|     <van-swipe-item v-for="(image,index) in images" :key="image" @click="clickSwipe(index)"> |  | ||||||
|       <van-image |  | ||||||
|           fit="contain" |  | ||||||
|           width="100%" |  | ||||||
|           :height="188" |  | ||||||
|           :src="image" |  | ||||||
|       /> |  | ||||||
|     </van-swipe-item> |  | ||||||
|   </van-swipe>--> |  | ||||||
|   <div class="px-[16px] bg-[#fff] pt-[11px] mb-6px"> |   <div class="px-[16px] bg-[#fff] pt-[11px] mb-6px"> | ||||||
|     <div class="text-[#000] text-[16px] mb-[12px]">{{detailInfo?.artworkTitle}}</div> |     <div class="text-[#000] text-[16px] mb-[12px]">{{detailInfo?.artworkTitle}}</div> | ||||||
|     <div class="text-#575757 text-[14px] pb-8px"> |     <div class="text-#575757 text-[14px] pb-8px"> | ||||||
|  | |||||||
| @ -1,3 +1,3 @@ | |||||||
| 
 | 
 | ||||||
| export const useAppFooterRouteNames= ['home', 'profile'] | export const useAppFooterRouteNames= ['index', 'profile'] | ||||||
| export const useAppHeaderRouteNames= ['home', 'profile','login','collectCode-login','collectCode-mine'] | export const useAppHeaderRouteNames= ['index', 'profile','login','collectCode-login','collectCode-mine'] | ||||||
|  | |||||||
| @ -3,24 +3,13 @@ import liveRoom from '@/pages/liveRoom/index.client.vue'; | |||||||
| import {goodStore} from "@/stores/goods/index.js"; | import {goodStore} from "@/stores/goods/index.js"; | ||||||
| import ItemList from './components/ItemList/index.vue' | import ItemList from './components/ItemList/index.vue' | ||||||
| import Cescribe from './components/Cescribe/index.vue' | import Cescribe from './components/Cescribe/index.vue' | ||||||
| 
 | const {fullLive, liveRef} = goodStore(); | ||||||
| import {artworkList} from "~/api/goods/index.js"; |  | ||||||
| import {ref} from "vue"; |  | ||||||
| 
 |  | ||||||
| const {fullLive, getAuctionDetail, auctionDetail, itemList, pageRef, liveRef} = goodStore(); |  | ||||||
| definePageMeta({ |  | ||||||
|   layout: 'default', |  | ||||||
|   title: '主页', |  | ||||||
|   i18n: 'menu.home', |  | ||||||
| }) |  | ||||||
| const changeLive = () => { | const changeLive = () => { | ||||||
|   fullLive.value = true; |   fullLive.value = true; | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
| 
 |  | ||||||
| <template> | <template> | ||||||
|   <div class="flex-grow-1"> |   <div class="flex-grow-1"> | ||||||
| 
 |  | ||||||
|     <client-only> |     <client-only> | ||||||
|       <liveRoom @click="changeLive" :class="['changeLive', fullLive ? 'expanded' : 'collapsed']" ref="liveRef" |       <liveRoom @click="changeLive" :class="['changeLive', fullLive ? 'expanded' : 'collapsed']" ref="liveRef" | ||||||
|                 :fullLive="fullLive"/> |                 :fullLive="fullLive"/> | ||||||
| @ -36,14 +25,8 @@ const changeLive = () => { | |||||||
|       </van-tabs> |       </van-tabs> | ||||||
|       <van-back-top right="15vw" bottom="10vh"/> |       <van-back-top right="15vw" bottom="10vh"/> | ||||||
|     </div> |     </div> | ||||||
| 
 |  | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| <style> |  | ||||||
| :root:root { |  | ||||||
|   --van-action-sheet-header-height: 39px; |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
| .ellipsis { | .ellipsis { | ||||||
|   display: -webkit-box; |   display: -webkit-box; | ||||||
|  | |||||||
| @ -1,6 +1,10 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import Home from './home/index.vue' | import Home from './home/index.vue' | ||||||
| 
 | definePageMeta({ | ||||||
|  |   layout: 'default', | ||||||
|  |   title: '主页', | ||||||
|  |   i18n: 'menu.home', | ||||||
|  | }) | ||||||
| </script> | </script> | ||||||
| <template> | <template> | ||||||
|   <Home/> |   <Home/> | ||||||
|  | |||||||
| @ -54,8 +54,6 @@ export const goodStore = createGlobalState(() => { | |||||||
|                 page: pageRef.value.page, |                 page: pageRef.value.page, | ||||||
|                 pageSize: pageRef.value.pageSize |                 pageSize: pageRef.value.pageSize | ||||||
|             }) |             }) | ||||||
|             console.log('res',res) |  | ||||||
| 
 |  | ||||||
|             if (res.status === 0) { |             if (res.status === 0) { | ||||||
|                 const newItems = res.data.data || [] |                 const newItems = res.data.data || [] | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								app/styles/default-theme.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								app/styles/default-theme.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,4 @@ | |||||||
|  | :root:root { | ||||||
|  |   --van-primary-color: var(--c-primary); | ||||||
|  |   --van-cell-group-inset-padding: 0; | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								app/styles/global.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								app/styles/global.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | |||||||
|  | #__nuxt { | ||||||
|  |   margin: 0; | ||||||
|  |   padding: 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | html { | ||||||
|  |   background: var(--van-gray-1); | ||||||
|  |   color-scheme: light; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | html.dark { | ||||||
|  |   background: #222; | ||||||
|  |   color-scheme: dark; | ||||||
|  | } | ||||||
							
								
								
									
										4
									
								
								app/styles/vars.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								app/styles/vars.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,4 @@ | |||||||
|  | :root { | ||||||
|  |   --c-primary: #3554AF; | ||||||
|  |   --c-primary-active: #3554AF; | ||||||
|  | } | ||||||
							
								
								
									
										195
									
								
								nuxt.config.js
									
									
									
									
									
								
							
							
						
						
									
										195
									
								
								nuxt.config.js
									
									
									
									
									
								
							| @ -1,18 +1,9 @@ | |||||||
| // 导入环境变量处理库
 |  | ||||||
| import dotenv from 'dotenv' | import dotenv from 'dotenv' | ||||||
| // 导入 Node.js 进程模块
 |  | ||||||
| import process from 'node:process' | import process from 'node:process' | ||||||
| // 导入预加载工具函数
 |  | ||||||
| import preload from './app/utils/preload' | import preload from './app/utils/preload' | ||||||
| // 导入国际化语言配置
 |  | ||||||
| import { currentLocales } from './i18n/i18n' | import { currentLocales } from './i18n/i18n' | ||||||
| 
 |  | ||||||
| // 设置环境变量文件路径,默认使用 .env.test
 |  | ||||||
| const envFile = process.env.ENV_FILE || '.env.test' | const envFile = process.env.ENV_FILE || '.env.test' | ||||||
| // 加载环境变量配置
 |  | ||||||
| dotenv.config({ path: `./env/${envFile}` }) | dotenv.config({ path: `./env/${envFile}` }) | ||||||
| 
 |  | ||||||
| // 过滤出以 NUXT_PUBLIC_ 开头的环境变量作为公共配置
 |  | ||||||
| const publicConfig = Object.entries(process.env) | const publicConfig = Object.entries(process.env) | ||||||
|     .filter(([key]) => key.startsWith('NUXT_PUBLIC_')) |     .filter(([key]) => key.startsWith('NUXT_PUBLIC_')) | ||||||
|     .reduce((config, [key, value]) => { |     .reduce((config, [key, value]) => { | ||||||
| @ -21,38 +12,38 @@ const publicConfig = Object.entries(process.env) | |||||||
|     }, {}) |     }, {}) | ||||||
| 
 | 
 | ||||||
| export default defineNuxtConfig({ | export default defineNuxtConfig({ | ||||||
|   // 注册 Nuxt 模块
 |  | ||||||
|   modules: [ |  | ||||||
|     '@nuxt/image',      // 图片优化模块
 |  | ||||||
|     '@vant/nuxt',       // Vant UI 组件库
 |  | ||||||
|     '@unocss/nuxt',     // 原子化 CSS 框架
 |  | ||||||
|     '@nuxtjs/i18n',     // 国际化模块
 |  | ||||||
|   ], |  | ||||||
| 
 | 
 | ||||||
|   // 运行时配置
 |   modules: [ | ||||||
|  |     '@vant/nuxt', | ||||||
|  |     '@unocss/nuxt', | ||||||
|  |       '@nuxt/image', | ||||||
|  |     '@nuxtjs/color-mode', | ||||||
|  |     '@nuxtjs/i18n', | ||||||
|  |   ], | ||||||
|   runtimeConfig: { |   runtimeConfig: { | ||||||
|     // 私有配置,只在服务端可用
 |     // 私有配置,只有在服务端可用
 | ||||||
|     apiSecret: process.env.NUXT_API_SECRET || 'default_secret', |     apiSecret: process.env.NUXT_API_SECRET || 'default_secret', | ||||||
|     // 公共配置,客户端和服务端都可用
 |     // 公共配置,客户端和服务端都可用
 | ||||||
|     public: publicConfig, |     public: publicConfig, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   // CSS 配置
 |  | ||||||
|   css: [ |   css: [ | ||||||
|     '@unocss/reset/tailwind.css', // 重置默认样式
 |     '@unocss/reset/tailwind.css', | ||||||
|     '@/static/styles/default-theme.css', |     '@/static/styles/default-theme.css', | ||||||
|   ], |   ], | ||||||
|   // PostCSS 配置
 | 
 | ||||||
|   postcss: { |   postcss: { | ||||||
|     plugins: { |     plugins: { | ||||||
|       'autoprefixer': {}, // 自动添加 CSS 前缀
 |       'autoprefixer': {}, | ||||||
|       // 移动端适配插件配置
 | 
 | ||||||
|  |       // https://github.com/wswmsword/postcss-mobile-forever
 | ||||||
|       'postcss-mobile-forever': { |       'postcss-mobile-forever': { | ||||||
|         appSelector: '#__nuxt',        // 根选择器
 |         appSelector: '#__nuxt', | ||||||
|         viewportWidth: 375,            // 设计稿宽度
 |         viewportWidth: 375, | ||||||
|         maxDisplayWidth: 600,          // 最大显示宽度
 |         maxDisplayWidth: 600, | ||||||
|         exclude: /@nuxt/,              // 排除的文件
 |         // devtools excluded
 | ||||||
|         border: true,                  // 显示边框
 |         exclude: /@nuxt/, | ||||||
|  |         border: true, | ||||||
|         rootContainingBlockSelectorList: [ |         rootContainingBlockSelectorList: [ | ||||||
|           'van-tabbar', |           'van-tabbar', | ||||||
|           'van-popup', |           'van-popup', | ||||||
| @ -61,153 +52,89 @@ export default defineNuxtConfig({ | |||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   // 国际化配置
 |   colorMode: { | ||||||
|   i18n: { |     classSuffix: '', | ||||||
|     locales: currentLocales,           // 支持的语言列表
 |     preference: 'system', | ||||||
|     lazy: true,                        // 懒加载语言包
 |     fallback: 'light', | ||||||
|     strategy: 'no_prefix',             // URL 策略:不添加语言前缀
 |     storageKey: 'nuxt-color-mode', | ||||||
|     detectBrowserLanguage: { |   }, | ||||||
|       useCookie: true,                 // 使用 cookie 存储语言选择
 | 
 | ||||||
|       cookieKey: 'i18n_redirected',    // cookie 键名
 |   i18n: { | ||||||
|       redirectOn: 'root',              // 仅在根路径重定向
 |     locales: currentLocales, | ||||||
|       alwaysRedirect: true,            // 总是重定向
 |     lazy: true, | ||||||
|       fallbackLocale: 'zh-CN'          // 默认语言
 |     strategy: 'no_prefix', | ||||||
|     }, |     detectBrowserLanguage: { | ||||||
|     langDir: 'locales',                // 语言文件目录
 |       useCookie: true, | ||||||
|     defaultLocale: 'zh-CN',            // 默认语言
 |       cookieKey: 'i18n_redirected', | ||||||
|     vueI18n: './i18n/i18n.config.ts',  // Vue I18n 配置文件
 |       redirectOn: 'root', | ||||||
|  |       alwaysRedirect: true, | ||||||
|  |       fallbackLocale: 'zh-CN' | ||||||
|  |     }, | ||||||
|  |     langDir: 'locales', | ||||||
|  |     defaultLocale: 'zh-CN', | ||||||
|  |     vueI18n: './i18n/i18n.config.ts', | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   // 应用配置
 |  | ||||||
|   app: { |   app: { | ||||||
|     // 布局过渡动画
 |  | ||||||
|     layoutTransition: { |     layoutTransition: { | ||||||
|       name: 'layout', |       name: 'layout', | ||||||
|       mode: 'out-in' |       mode: 'out-in' | ||||||
|     }, |     }, | ||||||
|     // 头部配置
 |  | ||||||
|     head: { |     head: { | ||||||
|       // 视口配置
 |  | ||||||
|       viewport: 'width=device-width,initial-scale=1,viewport-fit=cover', |       viewport: 'width=device-width,initial-scale=1,viewport-fit=cover', | ||||||
|       // 链接配置
 |  | ||||||
|       link: [ |       link: [ | ||||||
|         { rel: 'icon', href: '/favicon.ico', sizes: 'any' },           // 网站图标
 |         { rel: 'icon', href: '/favicon.ico', sizes: 'any' }, | ||||||
|         { rel: 'preload', as: 'style', href: '/critical.css' },        // 预加载关键 CSS
 |  | ||||||
|         { rel: 'preconnect', href: '你的API域名' },                     // 预连接 API 域名
 |  | ||||||
|         { rel: 'dns-prefetch', href: '你的API域名' },                   // DNS 预解析
 |  | ||||||
|       ], |       ], | ||||||
|       // Meta 标签配置
 |  | ||||||
|       meta: [ |       meta: [ | ||||||
|         { name: 'apple-mobile-web-app-capable', content: 'yes' },                    // iOS 应用模式
 |         { name: 'viewport', content: 'width=device-width, initial-scale=1, viewport-fit=cover,user-scalable=no' }, | ||||||
|         { name: 'apple-mobile-web-app-status-bar-style', content: 'black-translucent' }, // iOS 状态栏样式
 |         { name: 'apple-mobile-web-app-capable', content: 'yes' }, | ||||||
|         { name: 'theme-color', media: '(prefers-color-scheme: light)', content: '#ffffff' }, // 浅色主题色
 |         { name: 'apple-mobile-web-app-status-bar-style', content: 'black-translucent' }, | ||||||
|         { name: 'theme-color', media: '(prefers-color-scheme: dark)', content: '#222222' },  // 深色主题色
 |         { name: 'theme-color', media: '(prefers-color-scheme: light)', content: '#ffffff' }, | ||||||
|         { name: 'description', content: '你的网站描述' },                             // SEO 描述
 |         { name: 'theme-color', media: '(prefers-color-scheme: dark)', content: '#222222' }, | ||||||
|         { 'http-equiv': 'x-dns-prefetch-control', content: 'on' },                   // DNS 预解析控制
 |  | ||||||
|       ], |       ], | ||||||
|       // 脚本配置
 |  | ||||||
|       script: [ |       script: [ | ||||||
|         { innerHTML: preload(), type: 'text/javascript', tagPosition: 'head' },      // 预加载脚本
 |         { innerHTML: preload(), type: 'text/javascript', tagPosition: 'head' }, | ||||||
|         // 性能监控脚本
 |  | ||||||
|         { |  | ||||||
|           innerHTML: ` |  | ||||||
|           window.performance.mark('app-start'); |  | ||||||
|           new PerformanceObserver((entryList) => { |  | ||||||
|             for (const entry of entryList.getEntries()) { |  | ||||||
|               console.log('FCP:', entry.startTime); |  | ||||||
|             } |  | ||||||
|           }).observe({entryTypes: ['paint']}); |  | ||||||
|         `,
 |  | ||||||
|           type: 'text/javascript', |  | ||||||
|           tagPosition: 'head' |  | ||||||
|         } |  | ||||||
|       ], |       ], | ||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   // Vite 构建配置
 |  | ||||||
|   vite: { |   vite: { | ||||||
|     build: { |     build: { | ||||||
|       target: 'esnext',                // 构建目标
 |       target: 'esnext', | ||||||
|       // Rollup 配置
 |  | ||||||
|       rollupOptions: { |  | ||||||
|         output: { |  | ||||||
|           manualChunks: { |  | ||||||
|             'vant': ['vant'],          // Vant 单独打包
 |  | ||||||
|             'vendor': ['vue', 'vue-router'] // 核心库单独打包
 |  | ||||||
|           } |  | ||||||
|         } |  | ||||||
|     }, |     }, | ||||||
|       minify: 'terser',                // 使用 terser 压缩
 |  | ||||||
|       terserOptions: { |  | ||||||
|         compress: { |  | ||||||
|           drop_console: true,          // 移除 console
 |  | ||||||
|           drop_debugger: true          // 移除 debugger
 |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     // 依赖优化配置
 |  | ||||||
|     optimizeDeps: { |     optimizeDeps: { | ||||||
|       include: [ |       include: [ | ||||||
|         '@intlify/core-base',         // I18n 核心
 |         '@intlify/core-base', | ||||||
|         '@intlify/shared',            // I18n 共享库
 |         '@intlify/shared', | ||||||
|         'is-https',                   // HTTPS 检测
 |         'is-https', | ||||||
|         'vant',                       // Vant UI
 |  | ||||||
|         '@vant/use',                  // Vant Hooks
 |  | ||||||
|         '@vueuse/core',               // VueUse 工具集
 |  | ||||||
|       ], |       ], | ||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   // 实验性功能
 |  | ||||||
|   experimental: { |   experimental: { | ||||||
|     typedPages: true,                 // 启用页面类型
 |     typedPages: true, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   // 开发工具
 |  | ||||||
|   devtools: { |   devtools: { | ||||||
|     enabled: true,                    // 启用开发工具
 |     enabled: true, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   // TypeScript 配置
 |  | ||||||
|   typescript: { |   typescript: { | ||||||
|     shim: false,                      // 禁用 shim
 |     shim: false, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   // 功能特性配置
 |  | ||||||
|   features: { |   features: { | ||||||
|     inlineStyles: false,              // 禁用内联样式
 |     // For UnoCSS
 | ||||||
|  |     inlineStyles: false, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   // 未来特性配置
 |  | ||||||
|   future: { |   future: { | ||||||
|     compatibilityVersion: 4,          // 兼容性版本
 |     compatibilityVersion: 4, | ||||||
|   }, |   }, | ||||||
| 
 |   // 指定 Nuxt 应用程序的兼容性日期,确保应用程序在未来的 Nuxt 版本中保持稳定性
 | ||||||
|   // Nuxt 兼容性日期
 |   compatibilityDate: '2025-01-09', | ||||||
|   compatibilityDate: '2025-01-09',    // 确保未来版本兼容性
 |  | ||||||
| 
 |  | ||||||
|   // 开发服务器配置
 |  | ||||||
|   devServer: { |   devServer: { | ||||||
|     host: '0.0.0.0',                  // 主机地址
 |     host: '0.0.0.0', // Set the host to 'localhost'
 | ||||||
|     port: 3000,                       // 端口号
 |     port: 3000,        // Set the port to 3000 or any other port you prefer
 | ||||||
|   }, |   }, | ||||||
| 
 |  | ||||||
|   // 图片优化配置
 |  | ||||||
|   image: { |  | ||||||
|     provider: 'ipx',                  // 图片处理提供者
 |  | ||||||
|     // 响应式断点
 |  | ||||||
|     screens: { |  | ||||||
|       xs: 320,                        // 超小屏幕
 |  | ||||||
|       sm: 640,                        // 小屏幕
 |  | ||||||
|       md: 768,                        // 中等屏幕
 |  | ||||||
|       lg: 1024,                       // 大屏幕
 |  | ||||||
|       xl: 1280,                       // 超大屏幕
 |  | ||||||
|       xxl: 1536,                      // 特大屏幕
 |  | ||||||
|     }, |  | ||||||
|     quality: 80,                      // 图片质量
 |  | ||||||
|     format: ['webp', 'jpg'],          // 支持的格式
 |  | ||||||
|     placeholder: true,                // 启用占位图
 |  | ||||||
|     blur: 3                           // 模糊加载效果
 |  | ||||||
|   } |  | ||||||
| }) | }) | ||||||
| @ -726,6 +726,7 @@ packages: | |||||||
|   '@fastify/accept-negotiator@1.1.0': |   '@fastify/accept-negotiator@1.1.0': | ||||||
|     resolution: {integrity: sha512-OIHZrb2ImZ7XG85HXOONLcJWGosv7sIvM2ifAPQVhg9Lv7qdmMBNVaai4QTdyuaqbKM5eO6sLSQOYI7wEQeCJQ==} |     resolution: {integrity: sha512-OIHZrb2ImZ7XG85HXOONLcJWGosv7sIvM2ifAPQVhg9Lv7qdmMBNVaai4QTdyuaqbKM5eO6sLSQOYI7wEQeCJQ==} | ||||||
|     engines: {node: '>=14'} |     engines: {node: '>=14'} | ||||||
|  | 
 | ||||||
|   '@fingerprintjs/fingerprintjs@4.5.1': |   '@fingerprintjs/fingerprintjs@4.5.1': | ||||||
|     resolution: {integrity: sha512-hKJaRoLHNeUUPhb+Md3pTlY/Js2YR4aXjroaDHpxrjoM8kGnEFyZVZxXo6l3gRyKnQN52Uoqsycd3M73eCdMzw==} |     resolution: {integrity: sha512-hKJaRoLHNeUUPhb+Md3pTlY/Js2YR4aXjroaDHpxrjoM8kGnEFyZVZxXo6l3gRyKnQN52Uoqsycd3M73eCdMzw==} | ||||||
| 
 | 
 | ||||||
| @ -958,6 +959,9 @@ packages: | |||||||
|     peerDependencies: |     peerDependencies: | ||||||
|       vue: ^3.3.4 |       vue: ^3.3.4 | ||||||
| 
 | 
 | ||||||
|  |   '@nuxtjs/color-mode@3.5.2': | ||||||
|  |     resolution: {integrity: sha512-cC6RfgZh3guHBMLLjrBB2Uti5eUoGM9KyauOaYS9ETmxNWBMTvpgjvSiSJp1OFljIXPIqVTJ3xtJpSNZiO3ZaA==} | ||||||
|  | 
 | ||||||
|   '@nuxtjs/i18n@9.1.1': |   '@nuxtjs/i18n@9.1.1': | ||||||
|     resolution: {integrity: sha512-S8l5ri1GFo5OUsl9qSgicE9Sm0BZjVHU7p6ml1qhQUTewngnTPTlcytWX5etwJeAjHEu2w9VAV4qXTn9Q5EgmQ==} |     resolution: {integrity: sha512-S8l5ri1GFo5OUsl9qSgicE9Sm0BZjVHU7p6ml1qhQUTewngnTPTlcytWX5etwJeAjHEu2w9VAV4qXTn9Q5EgmQ==} | ||||||
|     engines: {node: ^14.16.0 || >=16.11.0} |     engines: {node: ^14.16.0 || >=16.11.0} | ||||||
| @ -4934,6 +4938,7 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   '@fastify/accept-negotiator@1.1.0': |   '@fastify/accept-negotiator@1.1.0': | ||||||
|     optional: true |     optional: true | ||||||
|  | 
 | ||||||
|   '@fingerprintjs/fingerprintjs@4.5.1': |   '@fingerprintjs/fingerprintjs@4.5.1': | ||||||
|     dependencies: |     dependencies: | ||||||
|       tslib: 2.8.1 |       tslib: 2.8.1 | ||||||
| @ -5144,7 +5149,7 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   '@nuxt/devtools-kit@1.6.4(magicast@0.3.5)(rollup@4.29.1)(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(sass@1.83.1)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1))': |   '@nuxt/devtools-kit@1.6.4(magicast@0.3.5)(rollup@4.29.1)(vite@6.0.5(@types/node@22.10.2)(jiti@2.4.2)(sass@1.83.1)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1))': | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@nuxt/kit': 3.15.0(magicast@0.3.5)(rollup@4.29.1) |       '@nuxt/kit': 3.15.2(magicast@0.3.5)(rollup@4.29.1) | ||||||
|       '@nuxt/schema': 3.15.0(magicast@0.3.5)(rollup@4.29.1) |       '@nuxt/schema': 3.15.0(magicast@0.3.5)(rollup@4.29.1) | ||||||
|       execa: 7.2.0 |       execa: 7.2.0 | ||||||
|       vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(sass@1.83.1)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) |       vite: 6.0.5(@types/node@22.10.2)(jiti@2.4.2)(sass@1.83.1)(terser@5.37.0)(tsx@4.19.2)(yaml@2.6.1) | ||||||
| @ -5161,7 +5166,7 @@ snapshots: | |||||||
|       global-directory: 4.0.1 |       global-directory: 4.0.1 | ||||||
|       magicast: 0.3.5 |       magicast: 0.3.5 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       pkg-types: 1.2.1 |       pkg-types: 1.3.1 | ||||||
|       prompts: 2.4.2 |       prompts: 2.4.2 | ||||||
|       rc9: 2.1.2 |       rc9: 2.1.2 | ||||||
|       semver: 7.6.3 |       semver: 7.6.3 | ||||||
| @ -5411,6 +5416,17 @@ snapshots: | |||||||
|       - vue-tsc |       - vue-tsc | ||||||
|       - yaml |       - yaml | ||||||
| 
 | 
 | ||||||
|  |   '@nuxtjs/color-mode@3.5.2(magicast@0.3.5)(rollup@4.29.1)': | ||||||
|  |     dependencies: | ||||||
|  |       '@nuxt/kit': 3.15.2(magicast@0.3.5)(rollup@4.29.1) | ||||||
|  |       pathe: 1.1.2 | ||||||
|  |       pkg-types: 1.3.1 | ||||||
|  |       semver: 7.6.3 | ||||||
|  |     transitivePeerDependencies: | ||||||
|  |       - magicast | ||||||
|  |       - rollup | ||||||
|  |       - supports-color | ||||||
|  | 
 | ||||||
|   '@nuxtjs/i18n@9.1.1(@vue/compiler-dom@3.5.13)(eslint@9.17.0(jiti@2.4.2))(magicast@0.3.5)(rollup@4.29.1)(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2))': |   '@nuxtjs/i18n@9.1.1(@vue/compiler-dom@3.5.13)(eslint@9.17.0(jiti@2.4.2))(magicast@0.3.5)(rollup@4.29.1)(typescript@5.7.2)(vue@3.5.13(typescript@5.7.2))': | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@intlify/h3': 0.6.1 |       '@intlify/h3': 0.6.1 | ||||||
| @ -7636,7 +7652,7 @@ snapshots: | |||||||
|   local-pkg@0.5.1: |   local-pkg@0.5.1: | ||||||
|     dependencies: |     dependencies: | ||||||
|       mlly: 1.7.3 |       mlly: 1.7.3 | ||||||
|       pkg-types: 1.2.1 |       pkg-types: 1.3.1 | ||||||
| 
 | 
 | ||||||
|   local-pkg@1.0.0: |   local-pkg@1.0.0: | ||||||
|     dependencies: |     dependencies: | ||||||
| @ -8064,7 +8080,7 @@ snapshots: | |||||||
|       consola: 3.3.1 |       consola: 3.3.1 | ||||||
|       execa: 8.0.1 |       execa: 8.0.1 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       pkg-types: 1.2.1 |       pkg-types: 1.3.1 | ||||||
|       ufo: 1.5.4 |       ufo: 1.5.4 | ||||||
| 
 | 
 | ||||||
|   nypm@0.4.1: |   nypm@0.4.1: | ||||||
| @ -9151,7 +9167,7 @@ snapshots: | |||||||
|       magic-string: 0.30.17 |       magic-string: 0.30.17 | ||||||
|       mlly: 1.7.3 |       mlly: 1.7.3 | ||||||
|       pathe: 1.1.2 |       pathe: 1.1.2 | ||||||
|       pkg-types: 1.2.1 |       pkg-types: 1.3.1 | ||||||
|       unplugin: 1.16.0 |       unplugin: 1.16.0 | ||||||
| 
 | 
 | ||||||
|   update-browserslist-db@1.1.1(browserslist@4.24.3): |   update-browserslist-db@1.1.1(browserslist@4.24.3): | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user