2025-06-09 18:49:32 +08:00
|
|
|
|
import { defineConfig, loadEnv } from "vite";
|
|
|
|
|
import path from "path";
|
|
|
|
|
import createVitePlugins from "./vite/plugins";
|
2025-05-30 13:16:11 +08:00
|
|
|
|
|
|
|
|
|
// https://vitejs.dev/config/
|
|
|
|
|
export default defineConfig(({ mode, command }) => {
|
2025-06-09 18:49:32 +08:00
|
|
|
|
const env = loadEnv(mode, process.cwd());
|
|
|
|
|
const { VITE_APP_ENV } = env;
|
|
|
|
|
const { VITE_APP_BASE_API } = env;
|
2025-05-30 13:16:11 +08:00
|
|
|
|
return {
|
|
|
|
|
// 部署生产环境和开发环境下的URL。
|
|
|
|
|
// 默认情况下,vite 会假设你的应用是被部署在一个域名的根路径上
|
|
|
|
|
// 例如 https://www.ruoyi.vip/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.ruoyi.vip/admin/,则设置 baseUrl 为 /admin/。
|
2025-06-09 18:49:32 +08:00
|
|
|
|
base: VITE_APP_ENV === "production" ? "/" : "/",
|
|
|
|
|
plugins: createVitePlugins(env, command === "build"),
|
2025-05-30 13:16:11 +08:00
|
|
|
|
resolve: {
|
|
|
|
|
// https://cn.vitejs.dev/config/#resolve-alias
|
|
|
|
|
alias: {
|
|
|
|
|
// 设置路径
|
2025-06-09 18:49:32 +08:00
|
|
|
|
"~": path.resolve(__dirname, "./"),
|
2025-05-30 13:16:11 +08:00
|
|
|
|
// 设置别名
|
2025-06-09 18:49:32 +08:00
|
|
|
|
"@": path.resolve(__dirname, "./src"),
|
2025-05-30 13:16:11 +08:00
|
|
|
|
},
|
|
|
|
|
// https://cn.vitejs.dev/config/#resolve-extensions
|
2025-06-09 18:49:32 +08:00
|
|
|
|
extensions: [".mjs", ".js", ".ts", ".jsx", ".tsx", ".json", ".vue"],
|
2025-05-30 13:16:11 +08:00
|
|
|
|
},
|
|
|
|
|
// 打包配置
|
|
|
|
|
build: {
|
|
|
|
|
// https://vite.dev/config/build-options.html
|
2025-06-09 18:49:32 +08:00
|
|
|
|
sourcemap: command === "build" ? false : "inline",
|
|
|
|
|
outDir: "dist",
|
|
|
|
|
assetsDir: "assets",
|
2025-05-30 13:16:11 +08:00
|
|
|
|
chunkSizeWarningLimit: 2000,
|
|
|
|
|
rollupOptions: {
|
|
|
|
|
output: {
|
2025-06-09 18:49:32 +08:00
|
|
|
|
chunkFileNames: "static/js/[name]-[hash].js",
|
|
|
|
|
entryFileNames: "static/js/[name]-[hash].js",
|
|
|
|
|
assetFileNames: "static/[ext]/[name]-[hash].[ext]",
|
|
|
|
|
},
|
|
|
|
|
},
|
2025-05-30 13:16:11 +08:00
|
|
|
|
},
|
|
|
|
|
// vite 相关配置
|
|
|
|
|
server: {
|
|
|
|
|
port: 80,
|
2025-06-09 18:49:32 +08:00
|
|
|
|
host: '0.0.0.0',
|
2025-05-30 13:16:11 +08:00
|
|
|
|
open: true,
|
2025-06-09 18:49:32 +08:00
|
|
|
|
headers: {
|
|
|
|
|
"Access-Control-Allow-Origin": "*",
|
|
|
|
|
},
|
2025-05-30 13:16:11 +08:00
|
|
|
|
proxy: {
|
2025-06-05 18:29:47 +08:00
|
|
|
|
'/apis': {
|
2025-05-30 13:16:11 +08:00
|
|
|
|
target: VITE_APP_BASE_API,
|
|
|
|
|
changeOrigin: true,
|
2025-06-09 18:49:32 +08:00
|
|
|
|
rewrite: (path) => path.replace(/^\/apis/, ""),
|
2025-05-30 13:16:11 +08:00
|
|
|
|
},
|
2025-06-09 18:49:32 +08:00
|
|
|
|
"^/v3/api-docs/(.*)": {
|
2025-05-30 13:16:11 +08:00
|
|
|
|
target: VITE_APP_BASE_API,
|
|
|
|
|
changeOrigin: true,
|
2025-06-09 18:49:32 +08:00
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
// proxy: {
|
|
|
|
|
// '/apis': {
|
|
|
|
|
// target: VITE_APP_BASE_API,
|
|
|
|
|
// changeOrigin: true,
|
|
|
|
|
// rewrite: (p) => p.replace(/^\/apis/, '')
|
|
|
|
|
// },
|
|
|
|
|
// '^/v3/api-docs/(.*)': {
|
|
|
|
|
// target: VITE_APP_BASE_API,
|
|
|
|
|
// changeOrigin: true,
|
|
|
|
|
// }
|
|
|
|
|
// }
|
2025-05-30 13:16:11 +08:00
|
|
|
|
},
|
|
|
|
|
css: {
|
|
|
|
|
postcss: {
|
|
|
|
|
plugins: [
|
|
|
|
|
{
|
2025-06-09 18:49:32 +08:00
|
|
|
|
postcssPlugin: "internal:charset-removal",
|
2025-05-30 13:16:11 +08:00
|
|
|
|
AtRule: {
|
|
|
|
|
charset: (atRule) => {
|
2025-06-09 18:49:32 +08:00
|
|
|
|
if (atRule.name === "charset") {
|
|
|
|
|
atRule.remove();
|
2025-05-30 13:16:11 +08:00
|
|
|
|
}
|
2025-06-09 18:49:32 +08:00
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
});
|