Files
WarehouseMgmt/web.vite/vite.config.ts

121 lines
3.8 KiB
TypeScript
Raw Normal View History

2025-10-09 13:58:21 +08:00
import { fileURLToPath } from "node:url";
import { defineConfig } from "vite";
import vue from "@vitejs/plugin-vue";
//import { visualizer } from 'rollup-plugin-visualizer'
import vueJsx from "@vitejs/plugin-vue-jsx";
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
// commonjs({
// // 这里可以配置插件的选项,例如指定需要转换的模块等
// include: 'node_modules/**', // 包含node_modules下的所有模块
// }),
{
name: "remove-pure-annotations",
transform(code) {
return code.replace(/\/\*#__PURE__\*\//g, "");
},
},
vue(),
vueJsx(),
// visualizer({
// // filename: 'report_form_rollup-plugin-visualizer.html'
// })
//引用后提示:
// requireTransform({
// fileRegex: /.js$|.ts$/
// })
],
define: {
//这里配置解决打印插件打包异常
// eval: "window.eval",
__VUE_PROD_HYDRATION_MISMATCH_DETAILS__: "true",
},
optimizeDeps: {
exclude: ["vue"],
},
// build: {
// minify: 'terser', // 使用 terser 以获得更精确的控制
// terserOptions: {
// exclude: [
// /node_modules\/vue-plugin-hiprint/, // 排除特定插件
// // 可以添加其他需要排除的模块
// ],
// compress: {
// defaults: true,
// drop_console: true,
// },
// mangle: true,
// },
// },
// base: '/test/',
build: {
//minify: false,
//minify: "terser", // 使用 terser 以获得更精确的控制
commonjsOptions: {
transformMixedEsModules: true,
},
chunkSizeWarningLimit: 1000, // 提高警告阈值
rollupOptions: {
onwarn(warning, warn) {
if (warning.code === "EMPTY_BUNDLE"||warning.code === 'EVAL'||warning.message.includes('larger than')) {
return;
}
warn(warning);
},
// external: ["vue-plugin-hiprint"],
output: {
// 保留formatter变量名
//minifyInternalExports: false,
//每个node_modules模块分成一个js文件
manualChunks(id) {
if (id.includes("node_modules")) {
return id
.toString()
.split("node_modules/")[1]
.split("/")[0]
.toString();
}
},
// 用于从入口点创建的块的打包输出格式[name]表示文件名,[hash]表示该文件内容hash值
// entryFileNames: 'assets/js/[name].[hash].js', // 用于命名代码拆分时创建的共享块的输出命名
// chunkFileNames: 'assets/js/[name].[hash].js', // 用于输出静态资源的命名,[ext]表示文件扩展名
// assetFileNames: 'assets/[ext]/[name].[hash].[ext]'
entryFileNames: "assets/js/[hash].js", // 用于命名代码拆分时创建的共享块的输出命名
chunkFileNames: "assets/js/[hash].js", // 用于输出静态资源的命名,[ext]表示文件扩展名
assetFileNames: "assets/[ext]/[hash].[ext]",
},
},
// outDir: 'dist', // 输出目录,默认为 'dist'
// rollupOptions: {
// input: {
// main: 'src/main.js', // 你的入口文件
// }
// },
sourcemap: false, //生成源映射文件
},
publicDir: "public", // 这里指定了 public 文件夹的位置
css: {
//查看CSS属于哪个css文件
devSourcemap: false,
},
server: {
port: 9000,
//配置代理
// proxy: {//http.js里设置为空axios.defaults.baseURL = "";
// '/api': {
// target:'http://proapi.volcore.xyz/',
// changeOrigin: true,
// timeout:1000*60*10
// //rewrite: (path) => path.replace(/^\/api/, '')
// }
// }
},
resolve: {
extensions: [".mjs", ".js", ".ts", ".jsx", ".tsx", ".json", ".vue", ".mjs"],
alias: {
"@": fileURLToPath(new URL("./src", import.meta.url)),
},
},
});