vite.config.ts 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. import vue from '@vitejs/plugin-vue';
  2. import { resolve } from 'path';
  3. import { defineConfig, ConfigEnv } from 'vite';
  4. import vueSetupExtend from 'vite-plugin-vue-setup-extend-plus'; // setup语法糖设置name
  5. import viteCompression from 'vite-plugin-compression'; //开启gzip打包压缩
  6. import vueJsx from '@vitejs/plugin-vue-jsx'; // jsx
  7. import { viteCommonjs } from '@originjs/vite-plugin-commonjs';
  8. // @ts-ignore
  9. export default defineConfig((mode: ConfigEnv) => {
  10. return {
  11. plugins: [
  12. vue(),
  13. vueSetupExtend(),
  14. viteCompression(),
  15. vueJsx({
  16. // options are passed on to @vue/babel-plugin-jsx
  17. }),
  18. viteCommonjs(),
  19. ],
  20. root: process.cwd(),
  21. resolve: { alias: { '@': resolve(__dirname, './src') } },
  22. base: mode.command === 'serve' ? './' : '/',
  23. hmr: true,
  24. server: {
  25. host: '0.0.0.0',
  26. port: 8888,
  27. open: true, // 是否打开浏览器
  28. },
  29. build: {
  30. outDir: 'dist',
  31. sourcemap: false,
  32. chunkSizeWarningLimit: 1500,
  33. rollupOptions: {
  34. output: {
  35. entryFileNames: `assets/[name].[hash].js`,
  36. chunkFileNames: `assets/[name].[hash].js`,
  37. assetFileNames: `assets/[name].[hash].[ext]`,
  38. compact: true,
  39. manualChunks: {
  40. vue: ['vue', 'vue-router', 'pinia'],
  41. },
  42. },
  43. },
  44. minify: 'terser',
  45. terserOptions: {
  46. //生产环境时移除console和debugger
  47. compress: {
  48. drop_console: false,
  49. drop_debugger: true,
  50. },
  51. },
  52. },
  53. css: {
  54. preprocessorOptions: {
  55. css: { charset: false },
  56. scss: {
  57. api: 'modern-compiler', // or 'modern'
  58. },
  59. },
  60. },
  61. };
  62. });