mirror of
https://github.com/un-pany/v3-admin-vite.git
synced 2025-04-20 10:59:21 +08:00
refactor: 重构 vite.config.ts 文件
This commit is contained in:
parent
226cdd3d1f
commit
4a0452d38e
@ -1,39 +1,37 @@
|
||||
/// <reference types="vitest/config" />
|
||||
|
||||
import type { ConfigEnv, UserConfigExport } from "vite"
|
||||
import path, { resolve } from "node:path"
|
||||
import { resolve } from "node:path"
|
||||
import vue from "@vitejs/plugin-vue"
|
||||
import vueJsx from "@vitejs/plugin-vue-jsx"
|
||||
import UnoCSS from "unocss/vite"
|
||||
import { loadEnv } from "vite"
|
||||
import { defineConfig, loadEnv } from "vite"
|
||||
import { createSvgIconsPlugin } from "vite-plugin-svg-icons"
|
||||
import svgLoader from "vite-svg-loader"
|
||||
|
||||
// 配置项文档:https://cn.vitejs.dev/config
|
||||
export default ({ mode }: ConfigEnv): UserConfigExport => {
|
||||
const viteEnv = loadEnv(mode, process.cwd()) as ImportMetaEnv
|
||||
const { VITE_PUBLIC_PATH } = viteEnv
|
||||
// Configuring Vite: https://cn.vite.dev/config
|
||||
export default defineConfig(({ mode }) => {
|
||||
const root = process.cwd()
|
||||
const { VITE_PUBLIC_PATH } = loadEnv(mode, root, "") as ImportMetaEnv
|
||||
return {
|
||||
// 打包时根据实际情况修改 base
|
||||
// 开发或打包构建时用到的公共基础路径
|
||||
base: VITE_PUBLIC_PATH,
|
||||
resolve: {
|
||||
alias: {
|
||||
// @ 符号指向 src 目录
|
||||
"@": resolve(__dirname, "./src")
|
||||
"@": resolve(__dirname, "src")
|
||||
}
|
||||
},
|
||||
// 开发环境服务器配置
|
||||
server: {
|
||||
// 设置 host: true 才可以使用 Network 的形式,以 IP 访问项目
|
||||
host: true, // host: "0.0.0.0"
|
||||
// 是否监听所有地址
|
||||
host: true,
|
||||
// 端口号
|
||||
port: 3333,
|
||||
// 是否自动打开浏览器
|
||||
open: false,
|
||||
// 跨域设置允许
|
||||
cors: true,
|
||||
// 端口被占用时,是否直接退出
|
||||
strictPort: false,
|
||||
// 接口代理
|
||||
// 是否自动打开浏览器
|
||||
open: false,
|
||||
// 反向代理
|
||||
proxy: {
|
||||
"/api/v1": {
|
||||
target: "https://mock.mengxuegu.com/mock/63218b5fb4c53348ed2bc212",
|
||||
@ -42,18 +40,16 @@ export default ({ mode }: ConfigEnv): UserConfigExport => {
|
||||
changeOrigin: true
|
||||
}
|
||||
},
|
||||
// 是否允许跨域
|
||||
cors: true,
|
||||
// 预热常用文件,提高初始页面加载速度
|
||||
warmup: {
|
||||
clientFiles: ["./src/layouts/**/*.vue"]
|
||||
}
|
||||
},
|
||||
// 构建配置
|
||||
build: {
|
||||
// 单个 chunk 文件的大小超过 2048KB 时发出警告
|
||||
chunkSizeWarningLimit: 2048,
|
||||
// 禁用 gzip 压缩大小报告
|
||||
reportCompressedSize: false,
|
||||
// 打包后静态资源目录
|
||||
assetsDir: "static",
|
||||
// 自定义底层的 Rollup 打包配置
|
||||
rollupOptions: {
|
||||
output: {
|
||||
/**
|
||||
@ -67,38 +63,43 @@ export default ({ mode }: ConfigEnv): UserConfigExport => {
|
||||
vxe: ["vxe-table", "vxe-table-plugin-element", "xe-utils"]
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
// 是否开启 gzip 压缩大小报告,禁用时能略微提高构建性能
|
||||
reportCompressedSize: false,
|
||||
// 单个 chunk 文件的大小超过 2048kB 时发出警告
|
||||
chunkSizeWarningLimit: 2048
|
||||
},
|
||||
// 混淆器
|
||||
esbuild:
|
||||
mode === "development"
|
||||
? undefined
|
||||
: {
|
||||
// 打包时移除 console.log
|
||||
// 打包构建时移除 console.log
|
||||
pure: ["console.log"],
|
||||
// 打包时移除 debugger
|
||||
// 打包构建时移除 debugger
|
||||
drop: ["debugger"],
|
||||
// 打包时移除所有注释
|
||||
// 打包构建时移除所有注释
|
||||
legalComments: "none"
|
||||
},
|
||||
// Vite 插件
|
||||
// 插件配置
|
||||
plugins: [
|
||||
vue(),
|
||||
// 支持 JSX、TSX 语法
|
||||
vueJsx(),
|
||||
// 将 SVG 静态图转化为 Vue 组件
|
||||
// 将 SVG 文件转化为 Vue 组件
|
||||
svgLoader({ defaultImport: "url" }),
|
||||
// SVG
|
||||
// 生成 SVG 雪碧图
|
||||
createSvgIconsPlugin({
|
||||
iconDirs: [path.resolve(process.cwd(), "src/icons/svg")],
|
||||
iconDirs: [resolve(root, "src/icons/svg")],
|
||||
symbolId: "icon-[dir]-[name]"
|
||||
}),
|
||||
// UnoCSS
|
||||
// 原子化 CSS
|
||||
UnoCSS()
|
||||
],
|
||||
// Vitest 单元测试配置:https://cn.vitest.dev/config
|
||||
// Configuring Vitest: https://cn.vitest.dev/config
|
||||
test: {
|
||||
include: ["tests/**/*.test.ts"],
|
||||
environment: "jsdom"
|
||||
}
|
||||
}
|
||||
}
|
||||
})
|
||||
|
Loading…
x
Reference in New Issue
Block a user