基于vue cli 通过命令行传参实现多环境配置


Posted in Javascript onJuly 12, 2018

大多数项目都有生产环境和开发环境,一般情况下应该够了,但是有时候还需要sit,uat,本地等环境,这时候假如要通过注释的方式切换环境就相当麻烦了. 如果可以像下面这样切换环境就方便了

npm run serve //默认本地开发环境

npm run serve -sit //本地开发中使用sit环境

npm run serve -uat //本地开发中使用uat环境

npm run build //默认打包后使用生产环境

npm run build -local //打包后使用本地环境

npm run build -sit //打包后使用sit环境

`npm run build -uat //打包后使用uat环境

如果对@vue/cli还不熟的话,建议看看这篇文章https://3water.com/article/138055.htm

我们首先在根目录下面创建一个vue.config.js文件,如图

基于vue cli 通过命令行传参实现多环境配置 

vue.config.js代码如下:

const webpack = require('webpack')
const environment = require('./build/environment')
module.exports = {
 baseUrl: '/wxperp/',
 configureWebpack: {
 plugins: [
 new webpack.DefinePlugin({
 'process.env.STAGE': JSON.stringify(environment.stage),
 'process.env.LOCAL_URL': JSON.stringify(environment.localUrl)
 })
 ]
 }
}

new webpack.DefinePlugin的作用是允许你创建一个在编译时可以配置的全局常量

然后在根目录创建一个build文件夹,里面创建一个environment.js的文件

基于vue cli 通过命令行传参实现多环境配置 

environment.js代码如下:

const os = require('os')
// 获取命令行变量
const configArgv = JSON.parse(process.env.npm_config_argv)
const original = configArgv.original.slice(1)
const stage = original[1] ? original[1].replace(/-/g, '') : ''
// 本地ip地址
let localUrl
try {
 const network = os.networkInterfaces()
 localUrl = network[Object.keys(network)[0]][1].address
} catch (e) {
 localUrl = 'localhost'
}
localUrl = 'http://' + localUrl + '/'

module.exports = {
 stage, localUrl
}

这个stage就是你输入的变量,比如你输入 npm run serve -sit 那么stage的值就为sit

这个localUrl就是你本地的ip,不过很多人应该用不到,我们公司比较特殊,开发的时候,接口请求的地址都是请求的自己本地服务器, 如果不自动获取本地ip,那么每个同事都得在配置文件中保留一份自己得ip地址,很麻烦,所以就自动获取了.

接下来再src目录下面创建一个config.js,记得在main.js中引用这个config.js

基于vue cli 通过命令行传参实现多环境配置 

environment.js代码如下:

(() => {
 const urlMap = {
 local: process.env.LOCAL_URL + 'api',
 sit: 'http://xxx.xxx.xxx:xxxx/sit/api',
 uat: 'http://xxx.xxx.xxx:xxxx/uat/api',
 prod: 'http://xxx.xxx.xxx:xxxx/prod/api'
 }
 //sit,uat,prod
 let stage = process.env.STAGE
 //development,production
 const nodeEnv = process.env.NODE_ENV
 //nodeEnv为production并且stage不存在默认为生产环境
 if (nodeEnv === 'production' && !stage) {
 stage = 'prod'
 } else {
 //stage不存在默认为本地开发环境
 stage = stage || 'local'
 }
 console.log('ip:' + urlMap[stage])
})()

我们输入 npm run serve -sit ,页面打印如下:

基于vue cli 通过命令行传参实现多环境配置 

再??孪?process.env.NODE_ENV是@vue/cli提供的,貌似有三个值(development,production,test),

你运行 npm run serve 得到的就是development

你运行 npm run build 得到的就是production

你运行 npm run test 得到的就是test (我没试过)

我默认打包是打包生产环境,当然你也可以输入参数打包其他环境

总结

以上所述是小编给大家介绍的基于vue cli 通过命令行传参实现多环境配置,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Firefox+FireBug使JQuery的学习更加轻松愉快
Jan 01 Javascript
IE6/7 and IE8/9/10(IE7模式)依次隐藏具有absolute或relative的父元素和子元素后再显示父元素
Jul 31 Javascript
js滚动条回到顶部的代码
Dec 06 Javascript
jquery.validate的使用说明介绍
Nov 12 Javascript
浅谈javascript中createElement事件
Dec 05 Javascript
javascript基于DOM实现省市级联下拉框的方法
May 14 Javascript
微信小程序 获取微信OpenId详解及实例代码
Oct 31 Javascript
node+experss实现爬取电影天堂爬虫
Nov 20 Javascript
简单实现Bootstrap标签页
Aug 09 Javascript
Javascript网页抢红包外挂实现分享
Jan 11 Javascript
Vue路由切换时的左滑和右滑效果示例
May 29 Javascript
JavaScript对象拷贝与Object.assign用法实例分析
Jun 20 Javascript
vue内置组件transition简单原理图文详解(小结)
Jul 12 #Javascript
vue-resource请求实现http登录拦截或者路由拦截的方法
Jul 11 #Javascript
vue.js实现的经典计算器/科学计算器功能示例
Jul 11 #Javascript
Vue.js实现的计算器功能完整示例
Jul 11 #Javascript
JavaScript类的继承方法小结【组合继承分析】
Jul 11 #Javascript
React中嵌套组件与被嵌套组件的通信过程
Jul 11 #Javascript
JSON数据中存在单个转义字符“\”的处理方法
Jul 11 #Javascript
You might like
落伍首发 php+mysql 采用ajax技术的 省 市 地 3级联动无刷新菜单 源码
2006/12/16 PHP
php中用socket模拟http中post或者get提交数据的示例代码
2013/08/08 PHP
PHP基于curl后台远程登录正方教务系统的方法
2016/10/14 PHP
thinkphp利用模型通用数据编辑添加和删除的实例代码
2016/11/20 PHP
PHP 实现文件压缩解压操作的方法
2019/06/14 PHP
apycom出品的jQuery精美菜单破解方法
2011/02/18 Javascript
Jquery写一个鼠标拖动效果实现原理与代码
2012/12/24 Javascript
jquery自定义类似$.ajax()的方法实现代码
2013/08/13 Javascript
div浮层,滚动条移动,位置保持不变的4种方法汇总
2013/12/11 Javascript
file控件选择上传文件确定后触发的js事件是哪个
2014/03/17 Javascript
使用JavaScript获取电池状态的方法
2014/05/03 Javascript
使用Plupload实现直接上传附件至七牛云存储
2014/12/26 Javascript
jquery实现在光标位置插入内容的方法
2015/02/05 Javascript
js禁止页面刷新与后退的方法
2015/06/08 Javascript
AngularJs定制样式插入到ueditor中的问题小结
2016/08/01 Javascript
Canvas 制作动态进度加载水球详解及实例代码
2016/12/09 Javascript
vue指令只能输入正数并且只能输入一个小数点的方法
2018/06/08 Javascript
vue form check 表单验证的实现代码
2018/12/09 Javascript
vue-test-utils初使用详解
2019/05/23 Javascript
vue使用代理解决请求跨域问题详解
2019/07/24 Javascript
vue element upload实现图片本地预览
2019/08/20 Javascript
[49:08]OpTic vs Serenity 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Django rest framework实现分页的示例
2018/05/24 Python
python 基本数据类型占用内存空间大小的实例
2018/06/12 Python
分析运行中的 Python 进程详细解析
2019/06/22 Python
解决python3 安装不了PIL的问题
2019/08/16 Python
Anaconda+vscode+pytorch环境搭建过程详解
2020/05/25 Python
Django-imagekit的使用详解
2020/07/06 Python
印度民族服装购物网站:BIBA
2019/08/05 全球购物
小学教师管理制度
2014/01/18 职场文书
初二生物教学反思
2014/02/03 职场文书
基督教婚礼主持词
2014/03/14 职场文书
卫生系统先进事迹
2014/05/13 职场文书
小学生读书活动总结
2014/06/30 职场文书
第一批党的群众路线教育实践活动总结报告
2014/07/03 职场文书
SQL Server数据库查询出现阻塞之性能调优
2022/04/10 SQL Server