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