2023-02-16 17:36:47 +08:00
|
|
|
|
/// <reference types="vitest" />
|
|
|
|
|
|
2022-10-18 15:07:42 +08:00
|
|
|
|
import { type ConfigEnv, type UserConfigExport, loadEnv } from "vite"
|
2022-04-22 01:16:02 +08:00
|
|
|
|
import path, { resolve } from "path"
|
|
|
|
|
import vue from "@vitejs/plugin-vue"
|
2022-10-25 17:29:28 +08:00
|
|
|
|
import vueJsx from "@vitejs/plugin-vue-jsx"
|
2022-04-22 01:16:02 +08:00
|
|
|
|
import { createSvgIconsPlugin } from "vite-plugin-svg-icons"
|
2022-09-29 22:38:27 +08:00
|
|
|
|
import svgLoader from "vite-svg-loader"
|
2022-08-15 16:34:05 +08:00
|
|
|
|
import UnoCSS from "unocss/vite"
|
2022-04-20 22:40:26 +08:00
|
|
|
|
|
2022-07-21 16:08:43 +08:00
|
|
|
|
/** 配置项文档:https://cn.vitejs.dev/config */
|
2022-08-19 23:01:07 +08:00
|
|
|
|
export default (configEnv: ConfigEnv): UserConfigExport => {
|
|
|
|
|
const viteEnv = loadEnv(configEnv.mode, process.cwd()) as ImportMetaEnv
|
|
|
|
|
const { VITE_PUBLIC_PATH } = viteEnv
|
2022-04-21 00:50:12 +08:00
|
|
|
|
return {
|
2022-07-01 16:25:51 +08:00
|
|
|
|
/** 打包时根据实际情况修改 base */
|
2022-08-19 23:01:07 +08:00
|
|
|
|
base: VITE_PUBLIC_PATH,
|
2022-04-21 00:50:12 +08:00
|
|
|
|
resolve: {
|
|
|
|
|
alias: {
|
|
|
|
|
/** @ 符号指向 src 目录 */
|
2022-04-22 01:16:02 +08:00
|
|
|
|
"@": resolve(__dirname, "./src")
|
2022-04-21 15:28:14 +08:00
|
|
|
|
}
|
2022-04-21 00:50:12 +08:00
|
|
|
|
},
|
2022-04-21 11:24:17 +08:00
|
|
|
|
server: {
|
2022-07-01 16:25:51 +08:00
|
|
|
|
/** 是否开启 HTTPS */
|
2022-04-21 11:24:17 +08:00
|
|
|
|
https: false,
|
2022-07-01 16:25:51 +08:00
|
|
|
|
/** 设置 host: true 才可以使用 Network 的形式,以 IP 访问项目 */
|
2022-04-21 11:24:17 +08:00
|
|
|
|
host: true, // host: "0.0.0.0"
|
|
|
|
|
/** 端口号 */
|
2022-04-28 15:38:49 +08:00
|
|
|
|
port: 3333,
|
2022-04-21 11:24:17 +08:00
|
|
|
|
/** 是否自动打开浏览器 */
|
|
|
|
|
open: false,
|
|
|
|
|
/** 跨域设置允许 */
|
|
|
|
|
cors: true,
|
2022-05-06 14:09:14 +08:00
|
|
|
|
/** 端口被占用时,是否直接退出 */
|
2022-09-22 11:45:03 +08:00
|
|
|
|
strictPort: false,
|
2022-04-21 11:24:17 +08:00
|
|
|
|
/** 接口代理 */
|
2022-09-22 11:45:03 +08:00
|
|
|
|
proxy: {
|
|
|
|
|
"/api/v1": {
|
|
|
|
|
target: "https://mock.mengxuegu.com/mock/63218b5fb4c53348ed2bc212/api/v1",
|
|
|
|
|
ws: true,
|
|
|
|
|
/** 是否允许跨域 */
|
|
|
|
|
changeOrigin: true,
|
|
|
|
|
rewrite: (path) => path.replace("/api/v1", "")
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-04-21 11:24:17 +08:00
|
|
|
|
},
|
|
|
|
|
build: {
|
|
|
|
|
/** 消除打包大小超过 500kb 警告 */
|
|
|
|
|
chunkSizeWarningLimit: 2000,
|
2022-07-01 16:25:51 +08:00
|
|
|
|
/** Vite 2.6.x 以上需要配置 minify: "terser", terserOptions 才能生效 */
|
2022-04-22 01:16:02 +08:00
|
|
|
|
minify: "terser",
|
2022-07-01 16:25:51 +08:00
|
|
|
|
/** 在打包代码时移除 console.log、debugger 和 注释 */
|
2022-04-21 11:24:17 +08:00
|
|
|
|
terserOptions: {
|
|
|
|
|
compress: {
|
|
|
|
|
drop_console: false,
|
|
|
|
|
drop_debugger: true,
|
2022-04-22 01:16:02 +08:00
|
|
|
|
pure_funcs: ["console.log"]
|
2022-04-21 11:24:17 +08:00
|
|
|
|
},
|
2022-07-15 10:48:29 +08:00
|
|
|
|
format: {
|
2022-04-21 11:24:17 +08:00
|
|
|
|
/** 删除注释 */
|
2022-04-21 15:28:14 +08:00
|
|
|
|
comments: false
|
|
|
|
|
}
|
2022-04-21 11:24:17 +08:00
|
|
|
|
},
|
2022-05-06 17:48:42 +08:00
|
|
|
|
/** 打包后静态资源目录 */
|
|
|
|
|
assetsDir: "static"
|
2022-04-21 11:24:17 +08:00
|
|
|
|
},
|
2022-07-01 16:25:51 +08:00
|
|
|
|
/** Vite 插件 */
|
2022-04-21 12:22:35 +08:00
|
|
|
|
plugins: [
|
|
|
|
|
vue(),
|
2022-10-25 17:29:28 +08:00
|
|
|
|
vueJsx(),
|
2022-09-29 22:38:27 +08:00
|
|
|
|
/** 将 SVG 静态图转化为 Vue 组件 */
|
2023-03-27 10:56:39 +08:00
|
|
|
|
svgLoader({ defaultImport: "url" }),
|
2022-07-01 16:25:51 +08:00
|
|
|
|
/** SVG */
|
2022-04-21 17:14:30 +08:00
|
|
|
|
createSvgIconsPlugin({
|
2022-04-22 01:16:02 +08:00
|
|
|
|
iconDirs: [path.resolve(process.cwd(), "src/icons/svg")],
|
|
|
|
|
symbolId: "icon-[dir]-[name]"
|
2022-05-12 19:07:54 +08:00
|
|
|
|
}),
|
2022-08-15 16:34:05 +08:00
|
|
|
|
/** UnoCSS */
|
2023-05-11 18:20:48 +08:00
|
|
|
|
UnoCSS()
|
2023-02-16 17:36:47 +08:00
|
|
|
|
],
|
|
|
|
|
/** Vitest 单元测试配置:https://cn.vitest.dev/config */
|
|
|
|
|
test: {
|
|
|
|
|
include: ["tests/**/*.test.ts"],
|
|
|
|
|
environment: "jsdom"
|
|
|
|
|
}
|
2022-04-21 00:50:12 +08:00
|
|
|
|
}
|
|
|
|
|
}
|