基于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 相关文章推荐
同一个表单 根据要求递交到不同页面的实现方法小结
Aug 05 Javascript
多浏览器兼容性比较好的复制到剪贴板的js代码
Oct 09 Javascript
Web开发之JavaScript
Mar 29 Javascript
javascript 判断字符串是否包含某字符串及indexOf使用示例
Oct 18 Javascript
jquery为页面增加快捷键示例
Jan 31 Javascript
回车直接实现点击某按钮的效果即触发单击事件
Feb 27 Javascript
js获取当前年月日-YYYYmmDD格式的实现代码
Jun 01 Javascript
JavaScript中 ES6 generator数据类型详解
Aug 11 Javascript
js实现图片粘贴上传到服务器并展示的实例
Nov 08 Javascript
详解vue+css3做交互特效的方法
Nov 20 Javascript
Bootstrap实现可折叠分组侧边导航菜单
Mar 07 Javascript
利用JavaScript的Map提升性能的方法详解
Aug 14 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
967 个函式
2006/10/09 PHP
一个基于PDO的数据库操作类(新) 一个PDO事务实例
2011/07/03 PHP
mysql,mysqli,PDO的各自不同介绍
2012/09/19 PHP
PHP连接MSSQL时nvarchar字段长度被截断为255的解决方法
2014/12/25 PHP
jQuery1.4.2与老版本json格式兼容的解决方法
2011/02/12 Javascript
windows8.1+iis8.5下安装node.js开发环境
2014/12/12 Javascript
Bootstrap入门书籍之(四)菜单、按钮及导航
2016/02/17 Javascript
基于jQuery实现仿百度首页选项卡切换效果
2016/05/29 Javascript
Angularjs修改密码的实例代码
2017/05/26 Javascript
protractor的安装与基本使用教程
2017/07/07 Javascript
jQuery实现腾讯信用界面(自制刻度尺)样式
2017/08/15 jQuery
React Native react-navigation 导航使用详解
2017/12/01 Javascript
vue登录路由验证的实现
2017/12/13 Javascript
vue.js移动数组位置,同时更新视图的方法
2018/03/08 Javascript
electron实现qq快捷登录的方法示例
2018/10/22 Javascript
详解关于微信setData回调函数中的坑
2019/02/18 Javascript
记录一次开发微信网页分享的步骤
2019/05/07 Javascript
node.JS二进制操作模块buffer对象使用方法详解
2020/02/06 Javascript
浅谈Vuex的this.$store.commit和在Vue项目中引用公共方法
2020/07/24 Javascript
[36:14]DOTA2上海特级锦标赛D组小组赛#1 EG VS COL第二局
2016/02/28 DOTA
Python计算库numpy进行方差/标准方差/样本标准方差/协方差的计算
2018/12/28 Python
Python字符串split及rsplit方法原理详解
2020/06/29 Python
CSS实现限制字数功能当对象内文本溢出时显示省略标记
2014/08/20 HTML / CSS
波兰数码相机及配件网上商店: Cyfrowe.pl
2017/06/19 全球购物
美国唇部护理专家:Sara Happ
2019/06/19 全球购物
出国留学自荐信
2013/10/25 职场文书
中学生在校期间的自我评价分享
2013/11/13 职场文书
职业女性的职业规划
2014/03/04 职场文书
商务英语专业毕业生求职信
2014/07/06 职场文书
物理分数没达标检讨书
2014/09/13 职场文书
2014年前台个人工作总结
2014/11/14 职场文书
2014年会计主管工作总结
2014/12/20 职场文书
优秀员工自荐书
2015/03/06 职场文书
关于倡议书的范文
2015/04/29 职场文书
无保留意见审计报告
2015/06/05 职场文书
goland设置颜色和字体的操作
2021/05/05 Golang