代码拉取完成,页面将自动刷新
import { loadEnv } from 'vite';
import vue from '@vitejs/plugin-vue'
import { resolve } from 'path'
import legacy from '@vitejs/plugin-legacy';
import Components from 'unplugin-vue-components/vite';
import { VantResolver } from "@vant/auto-import-resolver";
import postcssPxtorem from 'postcss-pxtorem';
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons';
// 获取当前模式(development 或 production)
const mode = process.env.NODE_ENV;
// 加载环境变量
const env = loadEnv(mode, process.cwd());
// https://vitejs.dev/config/
export default {
server: {
port: 4000, //指定端口号
host: '0.0.0.0', //可局域网IP访问
open: true,
proxy: proxy()
},
plugins: [
vue(),
Components({
resolvers: [VantResolver()],
}),
legacy({
targets: ['Chrome 69'],
modernPolyfills: true,
}),
createSvgIconsPlugin({
// 指定要处理的 SVG 文件夹路径
iconDirs: [resolve(process.cwd(), 'src/assets/icon')],
// 指定要生成的组件类型
symbolId: 'icon-[dir]-[name]',
})
],
resolve: {
alias: {
'@': '/src',
},
},
css: {
postcss: {
plugins: [
postcssPxtorem({
rootValue: 20,
exclude: /node_modules/,
propList: ['*'],// 需要转换的属性,这里选择全部转换
selectorBlackList: [".van"],//过滤掉van-开头的class
}),
],
},
},
base: '',//路径
build: {
rollupOptions: {
input: {
main: resolve(__dirname, 'index.html'),
// nested: resolve(__dirname, 'nested/index.html')
}
}
}
}
function proxy() {
if(!env.VITE_PROXY){
return {};
}
let obj = {};
let arr = JSON.parse(env.VITE_PROXY);
arr.forEach(item => {
obj[item[0]] = {
target: item[1], //跨域目标
changeOrigin: true,
// rewrite: (path) => path.replace(new RegExp(`^${item[0]}`), '')
}
});
return obj;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。