代码拉取完成,页面将自动刷新
import path from "path";
import { ConfigEnv, UserConfig } from "vite";
import vue from "@vitejs/plugin-vue";
import vueJsx from "@vitejs/plugin-vue-jsx";
import compression from "vite-plugin-compression";
import { visualizer } from "rollup-plugin-visualizer";
import { proxy } from "./src/config/proxy";
import { cool } from "@cool-vue/vite-plugin";
function resolve(dir: string) {
return path.resolve(__dirname, ".", dir);
}
function isDev(mode: string | undefined): boolean {
return mode === "development";
}
// https://vitejs.dev/config
export default ({ mode }: ConfigEnv): UserConfig => {
return {
plugins: [
vue(),
compression(),
vueJsx(),
cool({
type: "admin",
proxy
}),
visualizer({
open: false,
gzipSize: true,
brotliSize: true
})
],
base: "/",
server: {
port: 9000,
proxy,
hmr: {
overlay: true
}
},
css: {
preprocessorOptions: {
scss: {
charset: false
}
}
},
resolve: {
alias: {
"/@": resolve("src"),
"/$": resolve("src/modules"),
"/#": resolve("src/plugins"),
"/~": resolve("packages")
}
},
esbuild: {
drop: isDev(mode) ? [] : ["console", "debugger"]
},
build: {
minify: "esbuild",
// terserOptions: {
// compress: {
// drop_console: true,
// drop_debugger: true
// }
// },
sourcemap: isDev(mode),
rollupOptions: {
output: {
chunkFileNames: "static/js/[name]-[hash].js",
entryFileNames: "static/js/[name]-[hash].js",
assetFileNames: "static/[ext]/[name]-[hash].[ext]",
manualChunks(id) {
if (id.includes("node_modules")) {
if (!["@cool-vue/crud"].find((e) => id.includes(e))) {
let str = id.toString().split("node_modules/")[1];
if (str[0] == "@") {
str = str.replace("/", ".");
}
return str.split("/")[0].toString();
}
}
}
}
}
}
};
};
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。