Template
1
0
mirror of https://github.com/un-pany/v3-admin-vite.git synced 2025-04-22 03:49:19 +08:00
v3-admin-vite/vite.config.ts

110 lines
3.6 KiB
TypeScript
Raw Normal View History

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"
import path, { resolve } from "path"
import vue from "@vitejs/plugin-vue"
import vueJsx from "@vitejs/plugin-vue-jsx"
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"
// @ts-expect-error
2023-02-22 15:53:04 +08:00
import DefineOptions from "unplugin-vue-define-options/vite"
2022-04-20 22:40:26 +08:00
2022-07-21 16:08:43 +08:00
/** 配置项文档https://cn.vitejs.dev/config */
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 {
/** 打包时根据实际情况修改 base */
base: VITE_PUBLIC_PATH,
2022-04-21 00:50:12 +08:00
resolve: {
alias: {
/** @ 符号指向 src 目录 */
"@": resolve(__dirname, "./src")
}
2022-04-21 00:50:12 +08:00
},
server: {
/** 是否开启 HTTPS */
https: false,
/** 设置 host: true 才可以使用 Network 的形式,以 IP 访问项目 */
host: true, // host: "0.0.0.0"
/** 端口号 */
2022-04-28 15:38:49 +08:00
port: 3333,
/** 是否自动打开浏览器 */
open: false,
/** 跨域设置允许 */
cors: true,
2022-05-06 14:09:14 +08:00
/** 端口被占用时,是否直接退出 */
strictPort: false,
/** 接口代理 */
proxy: {
"/api/v1": {
target: "https://mock.mengxuegu.com/mock/63218b5fb4c53348ed2bc212/api/v1",
ws: true,
/** 是否允许跨域 */
changeOrigin: true,
rewrite: (path) => path.replace("/api/v1", "")
}
}
},
build: {
/** 消除打包大小超过 500kb 警告 */
chunkSizeWarningLimit: 2000,
/** Vite 2.6.x 以上需要配置 minify: "terser", terserOptions 才能生效 */
minify: "terser",
/** 在打包代码时移除 console.log、debugger 和 注释 */
terserOptions: {
compress: {
drop_console: false,
drop_debugger: true,
pure_funcs: ["console.log"]
},
2022-07-15 10:48:29 +08:00
format: {
/** 删除注释 */
comments: false
}
},
2022-05-06 17:48:42 +08:00
/** 打包后静态资源目录 */
assetsDir: "static"
},
/** Vite 插件 */
2022-04-21 12:22:35 +08:00
plugins: [
vue(),
vueJsx(),
2022-09-29 22:38:27 +08:00
/** 将 SVG 静态图转化为 Vue 组件 */
svgLoader({ defaultImport: "url" }),
/** SVG */
2022-04-21 17:14:30 +08:00
createSvgIconsPlugin({
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-02-22 15:53:04 +08:00
UnoCSS(),
/** DefineOptions 可以更简单的注册组件名称 */
DefineOptions()
/** 自动按需引入 (已更改为完整引入,所以注释了) */
// AutoImport({
// dts: "./types/auto-imports.d.ts",
// /** 自动按需导入 Element Plus 相关函数,比如 ElMessage */
// resolvers: [ElementPlusResolver()],
// /** 根据自动按需导入的相关 API生成 .eslintrc-auto-import.json 文件供 Eslint 识别 */
// eslintrc: {
// enabled: true, // 默认 false
// filepath: "./types/.eslintrc-auto-import.json", // 默认 "./.eslintrc-auto-import.json"
// globalsPropValue: true // 默认 true (true | false | "readonly" | "readable" | "writable" | "writeable")
// }
// }),
// Components({
// dts: "./types/components.d.ts",
// /** 自动按需导入 Element Plus 组件 */
// resolvers: [ElementPlusResolver()]
// })
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
}
}