Template
1
0
mirror of https://github.com/un-pany/v3-admin-vite.git synced 2025-04-22 11:59:19 +08:00
v3-admin-vite/vite.config.ts

85 lines
2.5 KiB
TypeScript
Raw Normal View History

2022-04-21 14:14:40 +08:00
import { ConfigEnv, UserConfigExport } from 'vite'
import { resolve } from 'path'
import vue from '@vitejs/plugin-vue'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
2022-04-20 22:40:26 +08:00
2022-04-21 00:50:12 +08:00
/** 配置项文档https://vitejs.dev/config */
export default (env: ConfigEnv): UserConfigExport => {
return {
resolve: {
alias: {
/** @ 符号指向 src 目录 */
'@': resolve(__dirname, './src')
}
2022-04-21 00:50:12 +08:00
},
server: {
/** 是否开启 https */
https: false,
/** host 设置为 true 才可以使用 network 的形式,以 ip 访问项目 */
host: true, // host: "0.0.0.0"
/** 端口号 */
port: 9999,
/** 是否自动打开浏览器 */
open: false,
/** 跨域设置允许 */
cors: true,
/** 如果端口已占用,直接退出 */
strictPort: true,
/** 接口代理 */
proxy: {
2022-04-21 14:14:40 +08:00
'/mock-api': {
target: 'https://vue-typescript-admin-mock-server-armour.vercel.app/mock-api',
ws: true,
/** 是否允许跨域 */
changeOrigin: true,
rewrite: (path) => path.replace('/mock-api', '')
}
}
},
build: {
brotliSize: false,
/** 消除打包大小超过 500kb 警告 */
chunkSizeWarningLimit: 2000,
/** vite 2.6.x 以上需要配置 minify: terserterserOptions 才能生效 */
2022-04-21 14:14:40 +08:00
minify: 'terser',
/** 在 build 代码时移除 console.log、debugger 和 注释 */
terserOptions: {
compress: {
drop_console: false,
drop_debugger: true,
pure_funcs: ['console.log']
},
output: {
/** 删除注释 */
comments: false
}
},
2022-04-21 14:14:40 +08:00
assetsDir: 'static/assets',
/** 静态资源打包到 dist 下的不同目录 */
rollupOptions: {
output: {
2022-04-21 14:14:40 +08:00
chunkFileNames: 'static/js/[name]-[hash].js',
entryFileNames: 'static/js/[name]-[hash].js',
assetFileNames: 'static/[ext]/[name]-[hash].[ext]'
}
}
},
2022-04-21 12:22:35 +08:00
/** vite 插件 */
plugins: [
vue(),
/** 自动按需导入 */
AutoImport({
2022-04-21 13:25:02 +08:00
dts: './src/types/auto-imports.d.ts',
resolvers: [ElementPlusResolver()]
2022-04-21 12:22:35 +08:00
}),
/** 自动按需导入 */
Components({
2022-04-21 13:25:02 +08:00
dts: './src/types/components.d.ts',
resolvers: [ElementPlusResolver()]
})
]
2022-04-21 00:50:12 +08:00
}
}