vue-cli3添加模式配置多环境变量的方法
时间:2021-04-10 08:50:14|栏目:vue|点击: 次
vue-cli3配置多环境变量
先挂官网描述:环境变量和模式
需求
根据运行环境判断执行代码:
- 预发环境操作完成跳转地址与线上环境跳转地址不同
- 线上环境添加埋点脚本
实现
Step1:在项目根目录中新建.env.uat
.env.uat配置如下:
VUE_APP_BUILD_TYPE=uat
vue-cli中规定,只有以 VUE_APP_ 开头的变量会被 webpack.DefinePlugin 静态嵌入到客户端侧的包中。
代码中可以通过 process.env.VUE_APP_SECRET
这样访问。
NODE_ENV 和 BASE_URL 是两个特殊变量,在代码中始终可用
Step2:修改 package.json
传递 --mode 选项参数为命令行覆写默认的模式。
"scripts": { "build": "vue-cli-service build", "build:uat": "vue-cli-service build --mode uat" }
Step3:使用
// 是否预发部署 const IS_UAT = process.env.VUE_APP_BUILD_TYPE === 'uat' const _url = IS_UAT ? 'http://a.123.com' : 'http://b.123.com' // 是否添加埋点 const IS_ADD_JAQ = process.env.NODE_ENV === 'production' && !IS_UAT if (IS_ADD_JAQ && loginUser) addJaq(loginUser) ...
优化
到这,功能已经实现了。
美滋滋地打个包,妈呀,体积也太大了:
此处解决办法为强写 NODE_ENV ,最终.env.uat配置如下:
NODE_ENV=production VUE_APP_BUILD_TYPE=uat
这样子顺眼些了,但整个项目打包这部分还是有很大的优化空间,下期再干咯~
总结
上一篇:让axios发送表单请求形式的键值对post数据的实例
栏 目:vue
下一篇:Vue 中 filter 与 computed 的区别与用法解析
本文地址:http://www.codeinn.net/misctech/98105.html