代码拉取完成,页面将自动刷新
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import path from 'path'
//@ts-ignore
import viteCompression from 'vite-plugin-compression'
import { getEntryPath } from './build/utils'
import Components from 'unplugin-vue-components/vite';
import { VantResolver } from 'unplugin-vue-components/resolvers';
import NutUIResolver from '@nutui/nutui/dist/resolver'
import { visualizer } from "rollup-plugin-visualizer"; //查看打包后文件分析
import { VitePWA } from "vite-plugin-pwa"; //离线缓存
// 让vite支持require
import requireTransform from "vite-plugin-require-transform";
// https://vitejs.dev/config/
export default defineConfig({
base: './', // 开发或生产环境服务的公共基础路径 配置引入相对路径
root: path.resolve(__dirname, 'src/pages'),//项目根目录(index.html 文件所在的位置)
plugins: [
VitePWA(),
visualizer(),
vue(),
requireTransform({
fileRegex: /.js$|.vue$/,
}),
// gzip压缩 生产环境生成 .gz 文件
viteCompression({
verbose: true, //默认即可
disable: false, //开启压缩(不禁用),默认即可
deleteOriginFile: false, //删除源文件
threshold: 10240, //压缩前最小文件大小(10k)
algorithm: "gzip", //压缩算法
ext: ".gz", //文件类型
}),
// 按需引入
Components({
resolvers: [VantResolver(), NutUIResolver()],
}),
],
// 配置别名
resolve: {
alias: {
'@': path.resolve(__dirname, 'src'),
},
},
css: {
preprocessorOptions: {
scss: {
additionalData: `@import "@nutui/nutui/dist/styles/variables.scss";`
}
}
},
//启动服务配置
server: {
host: '0.0.0.0',
port: 8000,
open: false,
https: false,
proxy: {}
},
// 生产环境打包配置
//去除 console debugger
build: {
outDir: '../../dist',// 指定dist打包文件输出路径
sourcemap: false, // 构建后是否生成 source map 文件
rollupOptions: {
input: {
index: path.resolve(__dirname, 'src/pages/index.html'),
...getEntryPath()
}//root路径下多页面文件入口配置
},
terserOptions: {
compress: {
drop_console: true,
drop_debugger: true,
},
},
},
})
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。