基于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 相关文章推荐
JQUERY1.6 使用方法四 检测浏览器
Nov 23 Javascript
自定义右键属性覆盖浏览器默认右键行为实现代码
Feb 02 Javascript
图片上传插件jquery.uploadify详解
Nov 15 Javascript
JS使用parseInt解析数字实现求和的方法
Aug 05 Javascript
如何利用AngularJS打造一款简单Web应用
Dec 05 Javascript
jQuery Easyui 验证两次密码输入是否相等
May 13 Javascript
在 React、Vue项目中使用SVG的方法
Feb 09 Javascript
微信小程序实现红包功能(后端PHP实现逻辑)
Jul 11 Javascript
vue里面使用mui的弹出日期选择插件实例
Sep 16 Javascript
Vue页面跳转动画效果的实现方法
Sep 23 Javascript
浅谈Fetch 数据交互方式
Dec 20 Javascript
Vue+Koa2+mongoose写一个像素绘板的实现方法
Sep 10 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购物车实现代码
2011/10/10 PHP
PHP中extract()函数的妙用分析
2012/07/11 PHP
探讨:php中在foreach中使用foreach ($arr as &$value) 这种类型的解释
2013/06/24 PHP
Zend Framework教程之Zend_Helpers动作助手ViewRenderer用法详解
2016/07/20 PHP
laravel返回统一格式错误码问题
2019/11/04 PHP
可缩放Reloaded-一个针对可缩放元素的复用组件
2007/03/10 Javascript
jQuery 常见学习网站与参考书
2009/11/09 Javascript
JS/FLASH实现复制代码到剪贴板(兼容所有浏览器)
2013/05/27 Javascript
javascript生成img标签的3种实现方法(对象、方法、html)
2015/12/25 Javascript
AngularJS中监视Scope变量以及外部调用Scope方法
2016/01/23 Javascript
Javascript的表单验证-初识正则表达式
2016/03/18 Javascript
AngularJS入门教程之控制器详解
2016/07/27 Javascript
Javascript创建类和对象详解
2017/05/31 Javascript
javascript实现QQ空间相册展示源码
2017/12/12 Javascript
用Golang运行JavaScript的实现示例
2019/11/25 Javascript
OpenLayers加载缩放控件使用方法详解
2020/09/25 Javascript
[04:51]TI10典藏宝瓶Ⅱ外观视频展示
2020/08/15 DOTA
Python实现TCP/IP协议下的端口转发及重定向示例
2016/06/14 Python
python控制windows剪贴板,向剪贴板中写入图片的实例
2018/05/31 Python
python中sort和sorted排序的实例方法
2019/08/26 Python
python实现机器人卡牌
2019/10/06 Python
numpy中三维数组中加入元素后的位置详解
2019/11/28 Python
浅谈Python中的继承
2020/06/19 Python
七年级生物教学反思
2014/01/30 职场文书
珍珠鸟教学反思
2014/02/01 职场文书
薪酬专员岗位职责
2014/02/18 职场文书
酒鬼酒广告词
2014/03/21 职场文书
先进党支部事迹材料
2014/12/24 职场文书
2015年乡镇妇联工作总结
2015/05/19 职场文书
中学语文教学反思
2016/02/16 职场文书
JS中一些高效的魔法运算符总结
2021/05/06 Javascript
zabbix监控mysql的实例方法
2021/06/02 MySQL
Python re.sub 反向引用的实现
2021/07/07 Python
Ajax异步刷新功能及简单案例
2021/11/20 Javascript
python开发制作好看的时钟效果
2022/05/02 Python
关于MySQL中explain工具的使用
2023/05/08 MySQL