基于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 相关文章推荐
Mootools 1.2教程 定时器和哈希简介
Sep 15 Javascript
禁止js文件缓存的代码
Apr 09 Javascript
基于jquery实现左右按钮点击的图片切换效果
Jan 27 Javascript
jquery+json实现数据二级联动的方法
Nov 28 Javascript
Jquery Easyui菜单组件Menu使用详解(15)
Dec 18 Javascript
BootStrap 获得轮播中的索引和当前活动的焦点对象
May 11 Javascript
详解原生JS动态添加和删除类
Mar 26 Javascript
Electron 调用命令行(cmd)
Sep 23 Javascript
微信小程序自定义yPicker组件实现省市区三级联动功能
Oct 29 Javascript
Node.js文本文件BOM头的去除方法
Nov 22 Javascript
在Angular项目使用socket.io实现通信的方法
Jan 05 Javascript
vue组件是如何解析及渲染的?
Jan 13 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动态变静态原理
2006/11/25 PHP
PHP 日常开发小技巧
2009/09/23 PHP
php浏览历史记录的方法
2015/03/10 PHP
PHP数据对象PDO操作技巧小结
2016/09/27 PHP
善用事件代理,警惕闭包的性能陷阱。
2011/01/20 Javascript
js相册效果代码(点击创建即可)
2013/04/16 Javascript
jquery操作checked属性以及disabled属性的多种方法
2014/06/20 Javascript
JS实现仿中关村论坛评分后弹出提示效果的方法
2015/02/23 Javascript
创建自己的jquery表格插件
2015/11/25 Javascript
jqGrid中文文档之选项设置
2015/12/02 Javascript
Bootstrap的popover(弹出框)2秒后定时消失的实现代码
2017/02/27 Javascript
JS判断时间段的实现代码
2017/06/14 Javascript
Angular2 父子组件通信方式的示例
2018/01/29 Javascript
Node Puppeteer图像识别实现百度指数爬虫的示例
2018/02/22 Javascript
vue 动态绑定背景图片的方法
2018/08/10 Javascript
原生javascript实现连连看游戏
2019/01/03 Javascript
浅谈v-for 和 v-if 并用时筛选条件方法
2019/11/07 Javascript
js 对象使用的小技巧实例分析
2019/11/08 Javascript
区分vue-router的hash和history模式
2020/10/03 Javascript
vue+element实现动态加载表单
2020/12/13 Vue.js
Python爬取十篇新闻统计TF-IDF
2018/01/03 Python
python写一个md5解密器示例
2018/02/23 Python
Python使用一行代码获取上个月是几月
2018/08/30 Python
Python3实现的判断环形链表算法示例
2019/03/07 Python
python内存动态分配过程详解
2019/07/15 Python
python读取与处理netcdf数据方式
2020/02/14 Python
python读取图像矩阵文件并转换为向量实例
2020/06/18 Python
python使用dlib进行人脸检测和关键点的示例
2020/12/05 Python
德国baby-markt婴儿用品瑞士网站:baby-markt.ch
2017/06/09 全球购物
Ray-Ban雷朋奥地利官网:全球领先的太阳眼镜品牌
2020/10/12 全球购物
Linux开机引导的步骤是什么
2014/02/26 面试题
学生周末回家住宿长期请假条
2014/02/15 职场文书
多媒体专业自我鉴定
2014/02/28 职场文书
公司请假条范文
2014/04/11 职场文书
企业团队精神心得体会
2016/01/19 职场文书
python实现图片批量压缩
2021/04/24 Python