基于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 相关文章推荐
[原创]站长必须要知道的javascript广告代码
May 30 Javascript
JavaScript中圆括号()和方括号[]的特殊用法疑问解答
Aug 06 Javascript
JavaScript中统计Textarea字数并提示还能输入的字符
Jun 10 Javascript
JavaScript实现点击文本自动定位到下拉框选中操作
Jun 15 Javascript
基于JS+Canves实现点击按钮水波纹效果
Sep 15 Javascript
JQuery中解决重复动画的方法
Oct 17 Javascript
深入理解选择框脚本[推荐]
Dec 13 Javascript
利用javascript实现的三种图片放大镜效果实例(附源码)
Jan 23 Javascript
vue数据双向绑定原理解析(get & set)
Mar 08 Javascript
JavaScript关联数组用法分析【概念、定义、遍历】
Mar 15 Javascript
详解在vue-cli中使用graphql即vue-apollo的用法
Sep 08 Javascript
vue使用Google Recaptcha验证的实现示例
Aug 23 Vue.js
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连接类
2013/06/07 PHP
非常全面的php日期时间运算汇总
2015/11/04 PHP
Zend Framework动作助手Redirector用法实例详解
2016/03/05 PHP
php实现图片按比例截取的方法
2017/02/06 PHP
jQuery获取地址栏参数插件(模仿C#)
2010/10/26 Javascript
JS 仿腾讯发表微博的效果代码
2013/12/25 Javascript
Jquery实现控件的隐藏和显示实例
2014/02/08 Javascript
jquery的父子兄弟节点查找示例代码
2014/03/03 Javascript
jquery动态改变form属性提交表单
2014/06/03 Javascript
jquery数组过滤筛选方法grep()简介
2014/06/06 Javascript
JavaScript 实现打印,打印预览,打印设置
2014/12/30 Javascript
jQuery选择器源码解读(五):tokenize的解析过程
2015/03/31 Javascript
Bootstrap Metronic完全响应式管理模板之菜单栏学习笔记
2016/07/08 Javascript
JavaScript计时器用法分析【setTimeout和clearTimeout】
2017/01/18 Javascript
微信JSAPI Ticket接口签名详解
2020/06/28 Javascript
node.js学习之断言assert的使用示例
2017/09/28 Javascript
PHP自动加载autoload和命名空间的应用小结
2017/12/01 Javascript
vue debug 二种方法
2018/09/16 Javascript
vue中h5端打开app(判断是安卓还是苹果)
2021/02/26 Vue.js
python 动态获取当前运行的类名和函数名的方法
2014/04/15 Python
pycharm 使用心得(一)安装和首次使用
2014/06/05 Python
python使用any判断一个对象是否为空的方法
2014/11/19 Python
在阿里云服务器上配置CentOS+Nginx+Python+Flask环境
2016/06/18 Python
python数据类型_元组、字典常用操作方法(介绍)
2017/05/30 Python
Python生成一个迭代器的实操方法
2019/06/18 Python
python3获取url文件大小示例代码
2019/09/18 Python
python+adb命令实现自动刷视频脚本案例
2020/04/23 Python
Python接收手机短信的代码整理
2020/08/02 Python
Jupyter notebook命令和编辑模式常用快捷键汇总
2020/11/17 Python
美国最好的钓鱼、狩猎和划船装备商店:Bass Pro Shops
2018/12/02 全球购物
旅游管理专业生自荐信范文
2014/01/02 职场文书
小学生演讲稿
2014/01/12 职场文书
销售员求职个人的自我评价
2014/02/19 职场文书
十佳少先队员演讲稿
2014/09/12 职场文书
丧事答谢词
2015/01/05 职场文书
公司财务管理制度
2015/08/04 职场文书