From 532ac96abbc5837521d2d03cead97af76b7b24d7 Mon Sep 17 00:00:00 2001 From: landaiqing <3517283258@qq.com> Date: Fri, 12 Apr 2024 00:04:05 +0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=90=9B=E4=BF=AE=E5=A4=8D(antd):=20?= =?UTF-8?q?=E4=BF=AE=E5=A4=8Dantd=E7=BB=84=E4=BB=B6=E6=8C=89=E9=9C=80?= =?UTF-8?q?=E5=AF=BC=E5=85=A5=E5=A4=B1=E8=B4=A5bug?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .cz-config.js | 10 +- .eslintrc-auto-import.json | 14 +- auto-import.d.ts | 12 + components.d.ts | 4 + src/views/login/LoginPage.vue | 1 + tsconfig.json | 4 +- vite.config.mts | 26 +- ....timestamp-1711172711463-e712dd6497908.mjs | 223 ------------------ 8 files changed, 52 insertions(+), 242 deletions(-) delete mode 100644 vite.config.mts.timestamp-1711172711463-e712dd6497908.mjs diff --git a/.cz-config.js b/.cz-config.js index 729abbc..503d873 100644 --- a/.cz-config.js +++ b/.cz-config.js @@ -22,7 +22,7 @@ module.exports = { { value: '⚡️性能', name: '性能: 提升性能' }, { value: '✅测试', name: '测试: 添加一个测试' }, { value: '🔧工具', name: '工具: 开发工具变动(构建、脚手架工具等)' }, - { value: '⏪回滚', name: '回滚: 代码回退' }, + { value: '⏪回滚', name: '回滚: 代码回退' } ], // scope 类型(定义之后,可通过上下键选择) @@ -36,11 +36,11 @@ module.exports = { ['auth', '对 auth 修改'], ['other', '其他修改'], // 如果选择 custom,后面会让你再输入一个自定义的 scope。也可以不设置此项,把后面的 allowCustomScopes 设置为 true - ['custom', '以上都不是?我要自定义'], + ['custom', '以上都不是?我要自定义'] ].map(([value, description]) => { return { value, - name: `${value.padEnd(30)} (${description})`, + name: `${value.padEnd(30)} (${description})` } }), @@ -76,7 +76,7 @@ module.exports = { '填写更加详细的变更描述(可选)。使用 "|" 换行:\n', breaking: '列举非兼容性重大的变更(可选):\n', footer: '列举出所有变更的 ISSUES CLOSED(可选)。 例如: #31, #34:\n', - confirmCommit: '确认提交?', + confirmCommit: '确认提交?' }, // 设置只有 type 选择了 feat 或 fix,才询问 breaking message @@ -87,7 +87,7 @@ module.exports = { // subject 限制长度 subjectLimit: 100, - breaklineChar: '|', // 支持 body 和 footer + breaklineChar: '|' // 支持 body 和 footer // footerPrefix : 'ISSUES CLOSED:' // askForBreakingChangeFirst : true, } diff --git a/.eslintrc-auto-import.json b/.eslintrc-auto-import.json index 11e5e4c..05fd05d 100644 --- a/.eslintrc-auto-import.json +++ b/.eslintrc-auto-import.json @@ -288,6 +288,18 @@ "watchThrottled": true, "watchTriggerable": true, "watchWithFilter": true, - "whenever": true + "whenever": true, + "acceptHMRUpdate": true, + "createPinia": true, + "defineStore": true, + "getActivePinia": true, + "mapActions": true, + "mapGetters": true, + "mapState": true, + "mapStores": true, + "mapWritableState": true, + "setActivePinia": true, + "setMapStoreSuffix": true, + "storeToRefs": true } } diff --git a/auto-import.d.ts b/auto-import.d.ts index 610dfb1..db76c43 100644 --- a/auto-import.d.ts +++ b/auto-import.d.ts @@ -6,6 +6,7 @@ export {} declare global { const EffectScope: typeof import('vue')['EffectScope'] + const acceptHMRUpdate: typeof import('pinia')['acceptHMRUpdate'] const asyncComputed: typeof import('@vueuse/core')['asyncComputed'] const autoResetRef: typeof import('@vueuse/core')['autoResetRef'] const computed: typeof import('vue')['computed'] @@ -19,6 +20,7 @@ declare global { const createEventHook: typeof import('@vueuse/core')['createEventHook'] const createGlobalState: typeof import('@vueuse/core')['createGlobalState'] const createInjectionState: typeof import('@vueuse/core')['createInjectionState'] + const createPinia: typeof import('pinia')['createPinia'] const createReactiveFn: typeof import('@vueuse/core')['createReactiveFn'] const createReusableTemplate: typeof import('@vueuse/core')['createReusableTemplate'] const createSharedComposable: typeof import('@vueuse/core')['createSharedComposable'] @@ -29,9 +31,11 @@ declare global { const debouncedWatch: typeof import('@vueuse/core')['debouncedWatch'] const defineAsyncComponent: typeof import('vue')['defineAsyncComponent'] const defineComponent: typeof import('vue')['defineComponent'] + const defineStore: typeof import('pinia')['defineStore'] const eagerComputed: typeof import('@vueuse/core')['eagerComputed'] const effectScope: typeof import('vue')['effectScope'] const extendRef: typeof import('@vueuse/core')['extendRef'] + const getActivePinia: typeof import('pinia')['getActivePinia'] const getCurrentInstance: typeof import('vue')['getCurrentInstance'] const getCurrentScope: typeof import('vue')['getCurrentScope'] const h: typeof import('vue')['h'] @@ -44,6 +48,11 @@ declare global { const isReadonly: typeof import('vue')['isReadonly'] const isRef: typeof import('vue')['isRef'] const makeDestructurable: typeof import('@vueuse/core')['makeDestructurable'] + const mapActions: typeof import('pinia')['mapActions'] + const mapGetters: typeof import('pinia')['mapGetters'] + const mapState: typeof import('pinia')['mapState'] + const mapStores: typeof import('pinia')['mapStores'] + const mapWritableState: typeof import('pinia')['mapWritableState'] const markRaw: typeof import('vue')['markRaw'] const nextTick: typeof import('vue')['nextTick'] const onActivated: typeof import('vue')['onActivated'] @@ -84,9 +93,12 @@ declare global { const resolveComponent: typeof import('vue')['resolveComponent'] const resolveRef: typeof import('@vueuse/core')['resolveRef'] const resolveUnref: typeof import('@vueuse/core')['resolveUnref'] + const setActivePinia: typeof import('pinia')['setActivePinia'] + const setMapStoreSuffix: typeof import('pinia')['setMapStoreSuffix'] const shallowReactive: typeof import('vue')['shallowReactive'] const shallowReadonly: typeof import('vue')['shallowReadonly'] const shallowRef: typeof import('vue')['shallowRef'] + const storeToRefs: typeof import('pinia')['storeToRefs'] const syncRef: typeof import('@vueuse/core')['syncRef'] const syncRefs: typeof import('@vueuse/core')['syncRefs'] const templateRef: typeof import('@vueuse/core')['templateRef'] diff --git a/components.d.ts b/components.d.ts index f536da0..6e274ae 100644 --- a/components.d.ts +++ b/components.d.ts @@ -7,9 +7,13 @@ export {} declare module 'vue' { export interface GlobalComponents { + AButton: typeof import('ant-design-vue/es')['Button'] ECharts: typeof import('./src/components/echarts/ECharts.vue')['default'] + LoginPage: typeof import('./src/views/login/LoginPage.vue')['default'] + Photo: typeof import('./src/components/photo/photo.vue')['default'] RouterLink: typeof import('vue-router')['RouterLink'] RouterView: typeof import('vue-router')['RouterView'] SvgIcon: typeof import('./src/components/svgIcon/SvgIcon.vue')['default'] + Tip: typeof import('./src/components/tip/tip.vue')['default'] } } diff --git a/src/views/login/LoginPage.vue b/src/views/login/LoginPage.vue index 7d683af..f401d5f 100644 --- a/src/views/login/LoginPage.vue +++ b/src/views/login/LoginPage.vue @@ -14,6 +14,7 @@ export default defineComponent({

Login

测试页面,看到这个,那么项目就成功跑起来了

+ Loading diff --git a/tsconfig.json b/tsconfig.json index 7c8129d..03f1565 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -42,7 +42,9 @@ "src/**/*.tsx", "src/**/*.d.ts", "src/**/*.vue", - "auto-import.d.ts" + "./auto-imports.d.ts", + "./components.d.ts", + "./.eslintrc-auto-import.json" ], "references": [ { diff --git a/vite.config.mts b/vite.config.mts index 98e7e42..cd2188c 100644 --- a/vite.config.mts +++ b/vite.config.mts @@ -57,6 +57,17 @@ export default defineConfig(({ mode, command }) => { }, plugins: [ vue(), + AutoImport({ + //安装两行后你会发现在组件中不用再导入ref,reactive等 + imports: ['vue', 'vue-router','@vueuse/core','pinia'], + dts: 'auto-import.d.ts', + //ant-design-vue + resolvers: [AntDesignVueResolver()], + eslintrc: { + enabled: true // 1、改为true用于生成eslint配置。2、生成后改回false,避免重复生成消耗 + + } + }), createHtmlPlugin({ minify: true, /** @@ -123,22 +134,13 @@ export default defineConfig(({ mode, command }) => { targets: ['chrome 52'], // 需要兼容的目标列表 additionalLegacyPolyfills: ['regenerator-runtime/runtime'] // 面向IE11时需要此插件 }), - AutoImport({ - //安装两行后你会发现在组件中不用再导入ref,reactive等 - imports: ['vue', 'vue-router','@vueuse/core'], - dts: 'auto-import.d.ts', - //ant-design-vue - resolvers: [AntDesignVueResolver()], - eslintrc: { - enabled: true // 1、改为true用于生成eslint配置。2、生成后改回false,避免重复生成消耗 - } - }), Components({ + dts: true, // 指定自动导入的组件位置,默认是 src/components - dirs: ['src/components'], + dirs: ['src/components','src/views'], //ant-design-vue - resolvers: [AntDesignVueResolver({ importStyle: true, resolveIcons: true })] + resolvers: [AntDesignVueResolver({ importStyle: "less", resolveIcons: true })] }) ], optimizeDeps: { diff --git a/vite.config.mts.timestamp-1711172711463-e712dd6497908.mjs b/vite.config.mts.timestamp-1711172711463-e712dd6497908.mjs deleted file mode 100644 index 1ce44f1..0000000 --- a/vite.config.mts.timestamp-1711172711463-e712dd6497908.mjs +++ /dev/null @@ -1,223 +0,0 @@ -// vite.config.mts -import { defineConfig, loadEnv } from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/vite@5.2.2_@types+node@20.11.30_less@4.2.0_terser@5.29.2/node_modules/vite/dist/node/index.js"; -import vue from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/@vitejs+plugin-vue@5.0.4_vite@5.2.2_vue@3.4.21/node_modules/@vitejs/plugin-vue/dist/index.mjs"; -import * as path from "path"; -import legacy from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/@vitejs+plugin-legacy@5.3.2_terser@5.29.2_vite@5.2.2/node_modules/@vitejs/plugin-legacy/dist/index.mjs"; -import AutoImport from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/unplugin-auto-import@0.17.5_@vueuse+core@10.9.0/node_modules/unplugin-auto-import/dist/vite.js"; -import Components from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/unplugin-vue-components@0.26.0_vue@3.4.21/node_modules/unplugin-vue-components/dist/vite.js"; -import { AntDesignVueResolver } from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/unplugin-vue-components@0.26.0_vue@3.4.21/node_modules/unplugin-vue-components/dist/resolvers.js"; -import { createSvgIconsPlugin } from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/vite-plugin-svg-icons@2.0.1_vite@5.2.2/node_modules/vite-plugin-svg-icons/dist/index.mjs"; -import autoprefixer from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/autoprefixer@10.4.19_postcss@8.4.38/node_modules/autoprefixer/lib/autoprefixer.js"; -import viteCompression from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/vite-plugin-compression@0.5.1_vite@5.2.2/node_modules/vite-plugin-compression/dist/index.mjs"; -import imagemin from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/unplugin-imagemin@0.5.18/node_modules/unplugin-imagemin/dist/vite.mjs"; -import { createHtmlPlugin } from "file:///E:/vue-projects/schisandra-cloud-album-front/node_modules/.pnpm/vite-plugin-html@3.2.2_vite@5.2.2/node_modules/vite-plugin-html/dist/index.mjs"; -var __vite_injected_original_dirname = "E:\\vue-projects\\schisandra-cloud-album-front"; -var vite_config_default = defineConfig(({ mode, command }) => { - const env = loadEnv(mode, process.cwd()); - return { - resolve: { - //设置别名 - alias: { - "@": path.resolve(__vite_injected_original_dirname, "src") - } - }, - css: { - // CSS 预处理器 - preprocessorOptions: { - //define global less variable - less: { - javascriptEnabled: true, - charset: false, - //禁用字符集声明(charset 选项用于控制是否在生成的 CSS 文件的头部添加 @charset "UTF-8";) - additionalData: '@import "./src/assets/styles/variables.less";' - } - }, - postcss: { - plugins: [ - autoprefixer({ - overrideBrowserslist: ["Chrome > 40", "ff > 31", "ie 11"] - }) - ] - } - }, - esbuild: { - // configure this value when the browser version of the development environment is lower - // minimum support es2015 - // https://esbuild.github.io/api/#target - target: "es2015", - include: /\.(ts|jsx|tsx)$/ - }, - plugins: [ - vue(), - createHtmlPlugin({ - minify: true, - /** - * 在这里写entry后,你将不需要在`index.html`内添加 script 标签,原有标签需要删除 - * @default src/main.ts - */ - entry: "src/main.ts", - filename: "index.html", - /** - * 如果你想将 `index.html`存放在指定文件夹,可以修改它,否则不需要配置 - * @default index.html - */ - template: "index.html", - /** - * 需要注入 index.html ejs 模版的数据 - */ - inject: { - data: { - title: env.VITE_TITLE_NAME - } - } - }), - imagemin({ - // Default mode sharp. support squoosh and sharp - mode: "sharp", - beforeBundle: true, - // Default configuration options for compressing different pictures - compress: { - jpg: { - quality: 10 - }, - jpeg: { - quality: 10 - }, - png: { - quality: 10 - }, - webp: { - quality: 10 - } - }, - conversion: [ - { from: "jpeg", to: "webp" }, - { from: "png", to: "webp" }, - { from: "JPG", to: "jpeg" } - ] - }), - viteCompression({ - verbose: true, - // 是否在控制台中输出压缩结果 - disable: false, - threshold: 10240, - // 如果体积大于阈值,将被压缩,单位为b,体积过小时请不要压缩,以免适得其反 - algorithm: "gzip", - // 压缩算法,可选['gzip',' brotliccompress ','deflate ','deflateRaw'] - ext: ".gz", - deleteOriginFile: true - // 源文件压缩后是否删除 - }), - // 修改 icons 相关配置 - createSvgIconsPlugin({ - // 指定需要缓存的图标文件夹 - iconDirs: [path.resolve(__vite_injected_original_dirname, "./src/assets/icons")] - }), - legacy({ - renderLegacyChunks: true, - modernPolyfills: true, - targets: ["chrome 52"], - // 需要兼容的目标列表 - additionalLegacyPolyfills: ["regenerator-runtime/runtime"] - // 面向IE11时需要此插件 - }), - AutoImport({ - //安装两行后你会发现在组件中不用再导入ref,reactive等 - imports: ["vue", "vue-router", "@vueuse/core"], - dts: "auto-import.d.ts", - //ant-design-vue - resolvers: [AntDesignVueResolver()], - eslintrc: { - enabled: true - // 1、改为true用于生成eslint配置。2、生成后改回false,避免重复生成消耗 - } - }), - Components({ - // 指定自动导入的组件位置,默认是 src/components - dirs: ["src/components"], - //ant-design-vue - resolvers: [AntDesignVueResolver({ importStyle: true, resolveIcons: true })] - }) - ], - optimizeDeps: { - include: ["core-js"] - }, - server: { - proxy: { - "/api": { - //target是代理的目标路径 - target: env.VITE_API_BASE_URL, - changeOrigin: true, - //必须要开启跨域 - rewrite: (path2) => path2.replace(/\/api/, "") - // 路径重写 - } - } - }, - build: { - // target: ['es2015'], // 设置最终构建的浏览器兼容目标 - moduleResolution: "node", - // 决定如何处理模块。 - outDir: "dist", - // 指定输出路径 - assetsDir: "assets", - // 指定生成静态文件目录 - assetsInlineLimit: "4096", - // 小于此阈值的导入或引用资源将内联为 base64 编码 - cssCodeSplit: true, - // 启用 CSS 代码拆分 - // cssTarget: '', // 允许用户为 CSS 的压缩设置一个不同的浏览器 target 与 build.target 一致 - sourcemap: false, - // 构建后是否生成 source map 文件 - // lib: {}, // 构建为库 - manifest: false, - // 当设置为 true,构建后将会生成 manifest.json 文件 - ssrManifest: false, - // 构建不生成 SSR 的 manifest 文件 - ssr: void 0, - // 生成面向 SSR 的构建 - minify: "terser", - // 指定使用哪种混淆器 - // 传递给 Terser 的更多 minify 选项 - terserOptions: { - compress: { - drop_console: true, - drop_debugger: true - } - }, - write: true, - // 启用将构建后的文件写入磁盘 - emptyOutDir: true, - // 构建时清空该目录 - brotliSize: true, - // 启用 brotli 压缩大小报告 - chunkSizeWarningLimit: 2e3, - // chunk 大小警告的限制 - watch: null, - // 设置为 {} 则会启用 rollup 的监听器 - rollupOptions: { - // 自定义底层的 Rollup 打包配置 - output: { - chunkFileNames: "js/[name]-[hash].js", - // 引入文件名的名称 - entryFileNames: "js/[name]-[hash].js", - // 包的入口文件名称 - assetFileNames: "[ext]/[name]-[hash].[ext]" - // 资源文件像 字体,图片等 - } - } - }, - output: { - // 最小化拆分包 - manualChunks(id) { - if (id.includes("node_modules")) { - return id.toString().split("node_modules/")[1].split("/")[0].toString(); - } - } - } - }; -}); -export { - vite_config_default as default -}; -//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.mts"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"E:\\\\vue-projects\\\\schisandra-cloud-album-front\";const __vite_injected_original_filename = \"E:\\\\vue-projects\\\\schisandra-cloud-album-front\\\\vite.config.mts\";const __vite_injected_original_import_meta_url = \"file:///E:/vue-projects/schisandra-cloud-album-front/vite.config.mts\";import { defineConfig, loadEnv } from 'vite'\r\nimport vue from '@vitejs/plugin-vue'\r\nimport * as path from 'path'\r\nimport legacy from '@vitejs/plugin-legacy'\r\n\r\n// \u81EA\u52A8\u5BFC\u5165vue\u4E2Dhook reactive ref\u7B49\r\nimport AutoImport from 'unplugin-auto-import/vite'\r\n//\u81EA\u52A8\u5BFC\u5165ui-\u7EC4\u4EF6 \u6BD4\u5982\u8BF4ant-design-vue  element-plus\u7B49\r\nimport Components from 'unplugin-vue-components/vite'\r\n//ant-design-vue\r\nimport { AntDesignVueResolver } from 'unplugin-vue-components/resolvers'\r\n\r\n// icons plugin\r\nimport { createSvgIconsPlugin } from 'vite-plugin-svg-icons'\r\n\r\nimport autoprefixer from 'autoprefixer'\r\n\r\nimport viteCompression from 'vite-plugin-compression'\r\nimport imagemin from 'unplugin-imagemin/vite'\r\n\r\n\r\nimport { createHtmlPlugin } from 'vite-plugin-html'\r\n\r\nexport default defineConfig(({ mode, command }) => {\r\n\tconst env = loadEnv(mode, process.cwd())\r\n\treturn {\r\n\t\tresolve: {\r\n\t\t\t//\u8BBE\u7F6E\u522B\u540D\r\n\t\t\talias: {\r\n\t\t\t\t'@': path.resolve(__dirname, 'src')\r\n\t\t\t}\r\n\t\t},\r\n\t\tcss: {\r\n\t\t\t// CSS \u9884\u5904\u7406\u5668\r\n\t\t\tpreprocessorOptions: {\r\n\t\t\t\t//define global less variable\r\n\t\t\t\tless: {\r\n\t\t\t\t\tjavascriptEnabled: true,\r\n\t\t\t\t\tcharset: false, //\u7981\u7528\u5B57\u7B26\u96C6\u58F0\u660E(charset \u9009\u9879\u7528\u4E8E\u63A7\u5236\u662F\u5426\u5728\u751F\u6210\u7684 CSS \u6587\u4EF6\u7684\u5934\u90E8\u6DFB\u52A0 @charset \"UTF-8\";)\r\n\t\t\t\t\tadditionalData: '@import \"./src/assets/styles/variables.less\";'\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\tpostcss: {\r\n\t\t\t\tplugins: [\r\n\t\t\t\t\tautoprefixer({\r\n\t\t\t\t\t\toverrideBrowserslist: ['Chrome > 40', 'ff > 31', 'ie 11']\r\n\t\t\t\t\t})\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t},\r\n\t\tesbuild: {\r\n\t\t\t// configure this value when the browser version of the development environment is lower\r\n\t\t\t// minimum support es2015\r\n\t\t\t// https://esbuild.github.io/api/#target\r\n\t\t\ttarget: 'es2015',\r\n\t\t\tinclude: /\\.(ts|jsx|tsx)$/\r\n\t\t},\r\n\t\tplugins: [\r\n\t\t\tvue(),\r\n\t\t\tcreateHtmlPlugin({\r\n\t\t\t\tminify: true,\r\n\t\t\t\t/**\r\n\t\t\t\t * \u5728\u8FD9\u91CC\u5199entry\u540E\uFF0C\u4F60\u5C06\u4E0D\u9700\u8981\u5728`index.html`\u5185\u6DFB\u52A0 script \u6807\u7B7E\uFF0C\u539F\u6709\u6807\u7B7E\u9700\u8981\u5220\u9664\r\n\t\t\t\t * @default src/main.ts\r\n\t\t\t\t */\r\n\t\t\t\tentry: 'src/main.ts',\r\n\t\t\t\tfilename: 'index.html',\r\n\t\t\t\t/**\r\n\t\t\t\t * \u5982\u679C\u4F60\u60F3\u5C06 `index.html`\u5B58\u653E\u5728\u6307\u5B9A\u6587\u4EF6\u5939\uFF0C\u53EF\u4EE5\u4FEE\u6539\u5B83\uFF0C\u5426\u5219\u4E0D\u9700\u8981\u914D\u7F6E\r\n\t\t\t\t * @default index.html\r\n\t\t\t\t */\r\n\t\t\t\ttemplate: 'index.html',\r\n\t\t\t\t/**\r\n\t\t\t\t * \u9700\u8981\u6CE8\u5165 index.html ejs \u6A21\u7248\u7684\u6570\u636E\r\n\t\t\t\t */\r\n\t\t\t\tinject: {\r\n\t\t\t\t\tdata: {\r\n\t\t\t\t\t\ttitle: env.VITE_TITLE_NAME,\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}),\r\n\t\t\timagemin({\r\n\t\t\t\t// Default mode sharp. support squoosh and sharp\r\n\t\t\t\tmode: 'sharp',\r\n\t\t\t\tbeforeBundle: true,\r\n\t\t\t\t// Default configuration options for compressing different pictures\r\n\t\t\t\tcompress: {\r\n\t\t\t\t\tjpg: {\r\n\t\t\t\t\t\tquality: 10\r\n\t\t\t\t\t},\r\n\t\t\t\t\tjpeg: {\r\n\t\t\t\t\t\tquality: 10\r\n\t\t\t\t\t},\r\n\t\t\t\t\tpng: {\r\n\t\t\t\t\t\tquality: 10\r\n\t\t\t\t\t},\r\n\t\t\t\t\twebp: {\r\n\t\t\t\t\t\tquality: 10\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\tconversion: [\r\n\t\t\t\t\t{ from: 'jpeg', to: 'webp' },\r\n\t\t\t\t\t{ from: 'png', to: 'webp' },\r\n\t\t\t\t\t{ from: 'JPG', to: 'jpeg' }\r\n\t\t\t\t]\r\n\t\t\t}),\r\n\t\t\tviteCompression({\r\n\t\t\t\tverbose: true, // \u662F\u5426\u5728\u63A7\u5236\u53F0\u4E2D\u8F93\u51FA\u538B\u7F29\u7ED3\u679C\r\n\t\t\t\tdisable: false,\r\n\t\t\t\tthreshold: 10240, // \u5982\u679C\u4F53\u79EF\u5927\u4E8E\u9608\u503C\uFF0C\u5C06\u88AB\u538B\u7F29\uFF0C\u5355\u4F4D\u4E3Ab\uFF0C\u4F53\u79EF\u8FC7\u5C0F\u65F6\u8BF7\u4E0D\u8981\u538B\u7F29\uFF0C\u4EE5\u514D\u9002\u5F97\u5176\u53CD\r\n\t\t\t\talgorithm: 'gzip', // \u538B\u7F29\u7B97\u6CD5\uFF0C\u53EF\u9009['gzip'\uFF0C' brotliccompress '\uFF0C'deflate '\uFF0C'deflateRaw']\r\n\t\t\t\text: '.gz',\r\n\t\t\t\tdeleteOriginFile: true // \u6E90\u6587\u4EF6\u538B\u7F29\u540E\u662F\u5426\u5220\u9664\r\n\t\t\t}),\r\n\t\t\t// \u4FEE\u6539 icons \u76F8\u5173\u914D\u7F6E\r\n\t\t\tcreateSvgIconsPlugin({\r\n\t\t\t\t// \u6307\u5B9A\u9700\u8981\u7F13\u5B58\u7684\u56FE\u6807\u6587\u4EF6\u5939\r\n\t\t\t\ticonDirs: [path.resolve(__dirname, './src/assets/icons')]\r\n\t\t\t}),\r\n\t\t\tlegacy({\r\n\t\t\t\trenderLegacyChunks: true,\r\n\t\t\t\tmodernPolyfills: true,\r\n\t\t\t\ttargets: ['chrome 52'], // \u9700\u8981\u517C\u5BB9\u7684\u76EE\u6807\u5217\u8868\r\n\t\t\t\tadditionalLegacyPolyfills: ['regenerator-runtime/runtime'] // \u9762\u5411IE11\u65F6\u9700\u8981\u6B64\u63D2\u4EF6\r\n\t\t\t}),\r\n\t\t\tAutoImport({\r\n\t\t\t\t//\u5B89\u88C5\u4E24\u884C\u540E\u4F60\u4F1A\u53D1\u73B0\u5728\u7EC4\u4EF6\u4E2D\u4E0D\u7528\u518D\u5BFC\u5165ref\uFF0Creactive\u7B49\r\n\t\t\t\timports: ['vue', 'vue-router','@vueuse/core'],\r\n\t\t\t\tdts: 'auto-import.d.ts',\r\n\t\t\t\t//ant-design-vue\r\n\t\t\t\tresolvers: [AntDesignVueResolver()],\r\n\t\t\t\teslintrc: {\r\n\t\t\t\t\tenabled: true // 1\u3001\u6539\u4E3Atrue\u7528\u4E8E\u751F\u6210eslint\u914D\u7F6E\u30022\u3001\u751F\u6210\u540E\u6539\u56DEfalse\uFF0C\u907F\u514D\u91CD\u590D\u751F\u6210\u6D88\u8017\r\n\r\n\t\t\t\t}\r\n\t\t\t}),\r\n\t\t\tComponents({\r\n\t\t\t\t// \u6307\u5B9A\u81EA\u52A8\u5BFC\u5165\u7684\u7EC4\u4EF6\u4F4D\u7F6E\uFF0C\u9ED8\u8BA4\u662F src/components\r\n\t\t\t\tdirs: ['src/components'],\r\n\t\t\t\t//ant-design-vue\r\n\t\t\t\tresolvers: [AntDesignVueResolver({ importStyle: true, resolveIcons: true })]\r\n\t\t\t})\r\n\t\t],\r\n\t\toptimizeDeps: {\r\n\t\t\tinclude: ['core-js']\r\n\t\t},\r\n\t\tserver: {\r\n\t\t\tproxy: {\r\n\t\t\t\t'/api': {\r\n\t\t\t\t\t//target\u662F\u4EE3\u7406\u7684\u76EE\u6807\u8DEF\u5F84\r\n\t\t\t\t\ttarget: env.VITE_API_BASE_URL,\r\n\t\t\t\t\tchangeOrigin: true, //\u5FC5\u987B\u8981\u5F00\u542F\u8DE8\u57DF\r\n\t\t\t\t\trewrite: (path) => path.replace(/\\/api/, '') // \u8DEF\u5F84\u91CD\u5199\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t},\r\n\t\tbuild: {\r\n\t\t\t// target: ['es2015'], // \u8BBE\u7F6E\u6700\u7EC8\u6784\u5EFA\u7684\u6D4F\u89C8\u5668\u517C\u5BB9\u76EE\u6807\r\n\t\t\tmoduleResolution: 'node', // \u51B3\u5B9A\u5982\u4F55\u5904\u7406\u6A21\u5757\u3002\r\n\t\t\toutDir: 'dist', // \u6307\u5B9A\u8F93\u51FA\u8DEF\u5F84\r\n\t\t\tassetsDir: 'assets', // \u6307\u5B9A\u751F\u6210\u9759\u6001\u6587\u4EF6\u76EE\u5F55\r\n\t\t\tassetsInlineLimit: '4096', // \u5C0F\u4E8E\u6B64\u9608\u503C\u7684\u5BFC\u5165\u6216\u5F15\u7528\u8D44\u6E90\u5C06\u5185\u8054\u4E3A base64 \u7F16\u7801\r\n\t\t\tcssCodeSplit: true, // \u542F\u7528 CSS \u4EE3\u7801\u62C6\u5206\r\n\t\t\t// cssTarget: '', // \u5141\u8BB8\u7528\u6237\u4E3A CSS \u7684\u538B\u7F29\u8BBE\u7F6E\u4E00\u4E2A\u4E0D\u540C\u7684\u6D4F\u89C8\u5668 target \u4E0E build.target \u4E00\u81F4\r\n\t\t\tsourcemap: false, // \u6784\u5EFA\u540E\u662F\u5426\u751F\u6210 source map \u6587\u4EF6\r\n\r\n\t\t\t// lib: {}, // \u6784\u5EFA\u4E3A\u5E93\r\n\t\t\tmanifest: false, // \u5F53\u8BBE\u7F6E\u4E3A true\uFF0C\u6784\u5EFA\u540E\u5C06\u4F1A\u751F\u6210 manifest.json \u6587\u4EF6\r\n\t\t\tssrManifest: false, // \u6784\u5EFA\u4E0D\u751F\u6210 SSR \u7684 manifest \u6587\u4EF6\r\n\t\t\tssr: undefined, // \u751F\u6210\u9762\u5411 SSR \u7684\u6784\u5EFA\r\n\t\t\tminify: 'terser', // \u6307\u5B9A\u4F7F\u7528\u54EA\u79CD\u6DF7\u6DC6\u5668\r\n\t\t\t// \u4F20\u9012\u7ED9 Terser \u7684\u66F4\u591A minify \u9009\u9879\r\n\t\t\tterserOptions: {\r\n\t\t\t\tcompress: {\r\n\t\t\t\t\tdrop_console: true,\r\n\t\t\t\t\tdrop_debugger: true\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\twrite: true, // \u542F\u7528\u5C06\u6784\u5EFA\u540E\u7684\u6587\u4EF6\u5199\u5165\u78C1\u76D8\r\n\t\t\temptyOutDir: true, // \u6784\u5EFA\u65F6\u6E05\u7A7A\u8BE5\u76EE\u5F55\r\n\t\t\tbrotliSize: true, // \u542F\u7528 brotli \u538B\u7F29\u5927\u5C0F\u62A5\u544A\r\n\t\t\tchunkSizeWarningLimit: 2000, // chunk \u5927\u5C0F\u8B66\u544A\u7684\u9650\u5236\r\n\t\t\twatch: null, // \u8BBE\u7F6E\u4E3A {} \u5219\u4F1A\u542F\u7528 rollup \u7684\u76D1\u542C\u5668\r\n\t\t\trollupOptions: {  // \u81EA\u5B9A\u4E49\u5E95\u5C42\u7684 Rollup \u6253\u5305\u914D\u7F6E\r\n\t\t\t\toutput: {\r\n\t\t\t\t\tchunkFileNames: 'js/[name]-[hash].js', // \u5F15\u5165\u6587\u4EF6\u540D\u7684\u540D\u79F0\r\n\t\t\t\t\tentryFileNames: 'js/[name]-[hash].js', // \u5305\u7684\u5165\u53E3\u6587\u4EF6\u540D\u79F0\r\n\t\t\t\t\tassetFileNames: '[ext]/[name]-[hash].[ext]' // \u8D44\u6E90\u6587\u4EF6\u50CF \u5B57\u4F53\uFF0C\u56FE\u7247\u7B49\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t},\r\n\t\toutput: {\r\n\t\t\t// \u6700\u5C0F\u5316\u62C6\u5206\u5305\r\n\t\t\tmanualChunks(id) {\r\n\t\t\t\tif (id.includes('node_modules')) {\r\n\t\t\t\t\treturn id.toString().split('node_modules/')[1].split('/')[0].toString()\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n})\r\n"],
  "mappings": "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",
  "names": ["path"]
}
