加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
vite.config.js 1.92 KB
一键复制 编辑 原始数据 按行查看 历史
夕空 提交于 2024-12-29 12:41 . 代理跨域
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;
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化