Compare commits
	
		
			No commits in common. "107966dabc7d10927f85e57fac097c5fa3a25ff7" and "8b144a270c55865b7310526f16b91c2528f11efa" have entirely different histories.
		
	
	
		
			107966dabc
			...
			8b144a270c
		
	
		
							
								
								
									
										23
									
								
								app/app.vue
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								app/app.vue
									
									
									
									
									
								
							| @ -1,17 +1,15 @@ | |||||||
| <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: [ | ||||||
|     {name: 'description', content: useI18n().t('appSetting.appDescription')}, |     { name: 'description', content: useI18n().t('appSetting.appDescription') }, | ||||||
|     {name: 'keywords', content: useI18n().t('appSetting.appKeyWords')}, |     { name: 'keywords', content: useI18n().t('appSetting.appKeyWords') }, | ||||||
|   ], |   ], | ||||||
| }) | }) | ||||||
| const color = useColorMode() |  | ||||||
| const mode = computed(() => { | const mode = computed(() => { | ||||||
|   return color.value |   return '' | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| // 添加路由中间件来处理过渡方向 | // 添加路由中间件来处理过渡方向 | ||||||
| @ -25,7 +23,7 @@ const routeHistory = ref([]) | |||||||
| router.beforeEach((to, from) => { | router.beforeEach((to, from) => { | ||||||
|   // 记录路由历史 |   // 记录路由历史 | ||||||
|   routeHistory.value.push(from.path) |   routeHistory.value.push(from.path) | ||||||
| 
 |    | ||||||
|   // 如果是返回操作(在历史记录中找到目标路由) |   // 如果是返回操作(在历史记录中找到目标路由) | ||||||
|   if (routeHistory.value.includes(to.path)) { |   if (routeHistory.value.includes(to.path)) { | ||||||
|     slideDirection.value = 'slide-right' |     slideDirection.value = 'slide-right' | ||||||
| @ -42,13 +40,13 @@ provide('slideDirection', slideDirection) | |||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <VanConfigProvider :theme="mode"> |   <VanConfigProvider theme="light"> | ||||||
|     <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> | ||||||
|       <NuxtPage :transition="{ |       <NuxtPage :transition="{ | ||||||
|         name: slideDirection |         name: slideDirection | ||||||
|       }"/> |       }" /> | ||||||
|     </NuxtLayout> |     </NuxtLayout> | ||||||
|   </VanConfigProvider> |   </VanConfigProvider> | ||||||
| </template> | </template> | ||||||
| @ -78,8 +76,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); | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
| @ -30,9 +30,7 @@ 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,7 +8,17 @@ 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> | ||||||
| @ -16,6 +26,16 @@ const props = defineProps({ | |||||||
|   <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= ['index', 'profile'] | export const useAppFooterRouteNames= ['home', 'profile'] | ||||||
| export const useAppHeaderRouteNames= ['index', 'profile','login','collectCode-login','collectCode-mine'] | export const useAppHeaderRouteNames= ['home', 'profile','login','collectCode-login','collectCode-mine'] | ||||||
|  | |||||||
| @ -3,13 +3,24 @@ 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"/> | ||||||
| @ -25,8 +36,14 @@ 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,10 +1,6 @@ | |||||||
| <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/> | ||||||
|  | |||||||
							
								
								
									
										0
									
								
								app/static/styles/global.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								app/static/styles/global.css
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										0
									
								
								app/static/styles/vars.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								app/static/styles/vars.css
									
									
									
									
									
										Normal file
									
								
							| @ -54,6 +54,8 @@ 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 || [] | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,4 +0,0 @@ | |||||||
| :root:root { |  | ||||||
|   --van-primary-color: var(--c-primary); |  | ||||||
|   --van-cell-group-inset-padding: 0; |  | ||||||
| } |  | ||||||
| @ -1,14 +0,0 @@ | |||||||
| #__nuxt { |  | ||||||
|   margin: 0; |  | ||||||
|   padding: 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| html { |  | ||||||
|   background: var(--van-gray-1); |  | ||||||
|   color-scheme: light; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| html.dark { |  | ||||||
|   background: #222; |  | ||||||
|   color-scheme: dark; |  | ||||||
| } |  | ||||||
| @ -1,4 +0,0 @@ | |||||||
| :root { |  | ||||||
|   --c-primary: #3554AF; |  | ||||||
|   --c-primary-active: #3554AF; |  | ||||||
| } |  | ||||||
							
								
								
									
										187
									
								
								nuxt.config.js
									
									
									
									
									
								
							
							
						
						
									
										187
									
								
								nuxt.config.js
									
									
									
									
									
								
							| @ -1,9 +1,18 @@ | |||||||
|  | // 导入环境变量处理库
 | ||||||
| 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]) => { | ||||||
| @ -12,38 +21,38 @@ const publicConfig = Object.entries(process.env) | |||||||
|     }, {}) |     }, {}) | ||||||
| 
 | 
 | ||||||
| export default defineNuxtConfig({ | export default defineNuxtConfig({ | ||||||
| 
 |   // 注册 Nuxt 模块
 | ||||||
|   modules: [ |   modules: [ | ||||||
|     '@vant/nuxt', |     '@nuxt/image',      // 图片优化模块
 | ||||||
|     '@unocss/nuxt', |     '@vant/nuxt',       // Vant UI 组件库
 | ||||||
|       '@nuxt/image', |     '@unocss/nuxt',     // 原子化 CSS 框架
 | ||||||
|     '@nuxtjs/color-mode', |     '@nuxtjs/i18n',     // 国际化模块
 | ||||||
|     '@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': {}, |       'autoprefixer': {}, // 自动添加 CSS 前缀
 | ||||||
| 
 |       // 移动端适配插件配置
 | ||||||
|       // 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,          // 最大显示宽度
 | ||||||
|         // devtools excluded
 |         exclude: /@nuxt/,              // 排除的文件
 | ||||||
|         exclude: /@nuxt/, |         border: true,                  // 显示边框
 | ||||||
|         border: true, |  | ||||||
|         rootContainingBlockSelectorList: [ |         rootContainingBlockSelectorList: [ | ||||||
|           'van-tabbar', |           'van-tabbar', | ||||||
|           'van-popup', |           'van-popup', | ||||||
| @ -52,89 +61,153 @@ export default defineNuxtConfig({ | |||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   colorMode: { |   // 国际化配置
 | ||||||
|     classSuffix: '', |  | ||||||
|     preference: 'system', |  | ||||||
|     fallback: 'light', |  | ||||||
|     storageKey: 'nuxt-color-mode', |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   i18n: { |   i18n: { | ||||||
|     locales: currentLocales, |     locales: currentLocales,           // 支持的语言列表
 | ||||||
|     lazy: true, |     lazy: true,                        // 懒加载语言包
 | ||||||
|     strategy: 'no_prefix', |     strategy: 'no_prefix',             // URL 策略:不添加语言前缀
 | ||||||
|     detectBrowserLanguage: { |     detectBrowserLanguage: { | ||||||
|       useCookie: true, |       useCookie: true,                 // 使用 cookie 存储语言选择
 | ||||||
|       cookieKey: 'i18n_redirected', |       cookieKey: 'i18n_redirected',    // cookie 键名
 | ||||||
|       redirectOn: 'root', |       redirectOn: 'root',              // 仅在根路径重定向
 | ||||||
|       alwaysRedirect: true, |       alwaysRedirect: true,            // 总是重定向
 | ||||||
|       fallbackLocale: 'zh-CN' |       fallbackLocale: 'zh-CN'          // 默认语言
 | ||||||
|     }, |     }, | ||||||
|     langDir: 'locales', |     langDir: 'locales',                // 语言文件目录
 | ||||||
|     defaultLocale: 'zh-CN', |     defaultLocale: 'zh-CN',            // 默认语言
 | ||||||
|     vueI18n: './i18n/i18n.config.ts', |     vueI18n: './i18n/i18n.config.ts',  // Vue I18n 配置文件
 | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|  |   // 应用配置
 | ||||||
|   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: 'viewport', content: 'width=device-width, initial-scale=1, viewport-fit=cover,user-scalable=no' }, |         { name: 'apple-mobile-web-app-capable', content: 'yes' },                    // iOS 应用模式
 | ||||||
|         { name: 'apple-mobile-web-app-capable', content: 'yes' }, |         { name: 'apple-mobile-web-app-status-bar-style', content: 'black-translucent' }, // iOS 状态栏样式
 | ||||||
|         { name: 'apple-mobile-web-app-status-bar-style', content: 'black-translucent' }, |         { name: 'theme-color', media: '(prefers-color-scheme: light)', content: '#ffffff' }, // 浅色主题色
 | ||||||
|         { name: 'theme-color', media: '(prefers-color-scheme: light)', content: '#ffffff' }, |         { name: 'theme-color', media: '(prefers-color-scheme: dark)', content: '#222222' },  // 深色主题色
 | ||||||
|         { name: 'theme-color', media: '(prefers-color-scheme: dark)', content: '#222222' }, |         { name: 'description', content: '你的网站描述' },                             // SEO 描述
 | ||||||
|  |         { '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', |         '@intlify/core-base',         // I18n 核心
 | ||||||
|         '@intlify/shared', |         '@intlify/shared',            // I18n 共享库
 | ||||||
|         'is-https', |         'is-https',                   // 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: false,                      // 禁用 shim
 | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|  |   // 功能特性配置
 | ||||||
|   features: { |   features: { | ||||||
|     // For UnoCSS
 |     inlineStyles: false,              // 禁用内联样式
 | ||||||
|     inlineStyles: false, |  | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|  |   // 未来特性配置
 | ||||||
|   future: { |   future: { | ||||||
|     compatibilityVersion: 4, |     compatibilityVersion: 4,          // 兼容性版本
 | ||||||
|   }, |   }, | ||||||
|   // 指定 Nuxt 应用程序的兼容性日期,确保应用程序在未来的 Nuxt 版本中保持稳定性
 | 
 | ||||||
|   compatibilityDate: '2025-01-09', |   // Nuxt 兼容性日期
 | ||||||
|  |   compatibilityDate: '2025-01-09',    // 确保未来版本兼容性
 | ||||||
|  | 
 | ||||||
|  |   // 开发服务器配置
 | ||||||
|   devServer: { |   devServer: { | ||||||
|     host: '0.0.0.0', // Set the host to 'localhost'
 |     host: '0.0.0.0',                  // 主机地址
 | ||||||
|     port: 3000,        // Set the port to 3000 or any other port you prefer
 |     port: 3000,                       // 端口号
 | ||||||
|   }, |   }, | ||||||
|  | 
 | ||||||
|  |   // 图片优化配置
 | ||||||
|  |   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,7 +726,6 @@ 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==} | ||||||
| 
 | 
 | ||||||
| @ -959,9 +958,6 @@ 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} | ||||||
| @ -4938,7 +4934,6 @@ 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 | ||||||
| @ -5149,7 +5144,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.2(magicast@0.3.5)(rollup@4.29.1) |       '@nuxt/kit': 3.15.0(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) | ||||||
| @ -5166,7 +5161,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.3.1 |       pkg-types: 1.2.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 | ||||||
| @ -5416,17 +5411,6 @@ 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 | ||||||
| @ -7652,7 +7636,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.3.1 |       pkg-types: 1.2.1 | ||||||
| 
 | 
 | ||||||
|   local-pkg@1.0.0: |   local-pkg@1.0.0: | ||||||
|     dependencies: |     dependencies: | ||||||
| @ -8080,7 +8064,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.3.1 |       pkg-types: 1.2.1 | ||||||
|       ufo: 1.5.4 |       ufo: 1.5.4 | ||||||
| 
 | 
 | ||||||
|   nypm@0.4.1: |   nypm@0.4.1: | ||||||
| @ -9167,7 +9151,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.3.1 |       pkg-types: 1.2.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