• zhangsan's avatar
    1 · 0c522693
    zhangsan authored
    0c522693
vite.config.ts 2.47 KB
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import legacy from '@vitejs/plugin-legacy'
import Components from 'unplugin-vue-components/vite'
import { VantResolver } from '@vant/auto-import-resolver'
import { VarletUIResolver } from 'unplugin-vue-components/resolvers'
import AutoImport from 'unplugin-auto-import/vite'
import { resolve } from 'path'
import vitePluginBundleObfuscator from 'vite-plugin-bundle-obfuscator';

export default defineConfig({
  plugins: [
    vue(),
    // 添加 legacy 插件支持旧版浏览器
    legacy({
      targets: ['ie >= 11', 'chrome >= 49', 'ios >= 8'],
      additionalLegacyPolyfills: ['regenerator-runtime/runtime'],
      modernPolyfills: true
    }),
    AutoImport({
      imports: [
        'vue',
        'vue-router',
      ],
      resolvers: [VantResolver()],
    }),
    Components({
      resolvers: [
        VantResolver({
          importStyle: true
        }),
        VarletUIResolver({
          autoImport: true,
          importStyle: true,
          resolveStyles: true,
          version: '2.22.8'
        })
      ],
      dirs: ['src/components']
    }),
    // vitePluginBundleObfuscator({
    //   enable: true,
    //   log: true,
    //   autoExcludeNodeModules: true,
    //   threadPool: true,
    // })
  ],
  resolve: {
    alias: {
      '@': resolve(__dirname, 'src')
    }
  },
  css: {
    preprocessorOptions: {
      scss: {
        additionalData: `
          @use "sass:math";
          @use "@/styles/variables" as *;
          @use "@/styles/mixins" as *;
        `,
        sassOptions: {
          outputStyle: 'compressed'
        }
      }
    },
    postcss: {
      plugins: [
        require('postcss-px-to-viewport')({
          viewportWidth: 375,
          unitPrecision: 5,
          viewportUnit: 'vw',
          fontViewportUnit: 'vw',
          selectorBlackList: ['.ignore'],
          minPixelValue: 1,
          mediaQuery: false,
          exclude: /node_modules/i,
          propList: ['*', '!border*', '!font-size*', '!line-height*']
        })
      ]
    }
  },
  build: {
    target: 'es5',
    minify: 'terser',
    terserOptions: {
      compress: {
        drop_console: true,
        drop_debugger: true
      }
    }
  },
  server: {
    port: 8080,
    open: true,
    proxy: {
      '/api': {
        target: 'https://vip.cnrmjs20.com/api',
        // target: 'http://27.124.5.14:9013',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, '')
      }
    }
  }
})