• zhangsan's avatar
    '1' · d8e698dd
    zhangsan authored
    d8e698dd
vite.config.ts 1.8 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 { fileURLToPath, URL } from 'url'

// https://vitejs.dev/config/
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()],
      dts: 'src/auto-imports.d.ts'
    }),
    Components({
      resolvers: [
        VantResolver({
          importStyle: true
        }),
        VarletUIResolver({
          autoImport: true,
          importStyle: true,
        })
      ],
      dts: 'src/components.d.ts',
      dirs: ['src/components']
    })
  ],
  resolve: {
    alias: {
      '@': fileURLToPath(new URL('./src', import.meta.url))
    }
  },
  css: {
    preprocessorOptions: {
      scss: {
        additionalData: `
          @use "sass:math";
          @use "@/styles/variables.scss" as *;
          @use "@/styles/mixins.scss" as *;
        `
      }
    }
  },
  build: {
    target: 'es2015',
    minify: 'terser',
    terserOptions: {
      compress: {
        drop_console: true,
        drop_debugger: true
      }
    }
  },
  server: {
    host: true,
    port: 8080,
    proxy: {
      '/api': {
        target: 'http://27.124.5.14:9023',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, '')
      }
    }
  }
})