基于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 相关文章推荐
jquery 插件 人性化的消息显示
Jan 21 Javascript
JavaScript CSS菜单功能 改进版
Dec 20 Javascript
12行javascript代码绘制一个八卦图
Apr 02 Javascript
JS实现按比例缩放图片的方法(附C#版代码)
Dec 08 Javascript
jQuery插件开发汇总
May 15 Javascript
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
Dec 15 Javascript
canvas+gif.js打造自己的数字雨头像的示例代码
Oct 26 Javascript
JavaScript实现重力下落与弹性效果的方法分析
Dec 20 Javascript
AngularJS中的作用域实例分析
May 16 Javascript
vue增加强缓存和版本号的实现方法
May 01 Javascript
Vue.js构建你的第一个包并在NPM上发布的方法步骤
May 01 Javascript
微信小程序连接服务器展示MQTT数据信息的实现
Jul 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
DC宇宙的第一个英雄,堪称动漫史鼻祖,如今成为美国文化的象征
2020/04/09 欧美动漫
php通过会话控制实现身份验证实例
2016/10/18 PHP
简洁Ajax函数处理(示例代码)
2013/11/15 Javascript
html的DOM中document对象anchors集合用法实例
2015/01/21 Javascript
JavaScript时间操作之年月日星期级联操作
2016/01/15 Javascript
JavaScript中的Array 对象(数组对象)
2016/06/02 Javascript
js滚轮事件兼容性问题需要注意哪些
2016/11/15 Javascript
BootStrap的双日历时间控件使用
2017/07/25 Javascript
React Native react-navigation 导航使用详解
2017/12/01 Javascript
JavaScrip关于创建常量的知识点
2017/12/07 Javascript
Vue的实例、生命周期与Vue脚手架(vue-cli)实例详解
2017/12/27 Javascript
Angular HMR(热模块替换)功能实现方法
2018/04/04 Javascript
详解vuex commit保存数据技巧
2018/12/25 Javascript
详解vue 组件的实现原理
2020/11/12 Javascript
[48:00]EG vs LGD 2018国际邀请赛淘汰赛BO3 第二场 8.26
2018/08/29 DOTA
[01:06]欢迎来到上海,TI9
2018/08/26 DOTA
python使用7z解压apk包的方法
2015/04/18 Python
python append、extend与insert的区别
2016/10/13 Python
Django的信号机制详解
2017/05/05 Python
python得到windows自启动列表的方法
2018/10/14 Python
Python单元测试unittest的具体使用示例
2018/12/17 Python
Django 查询数据库并返回页面的例子
2019/08/12 Python
python是否适合网页编程详解
2019/10/04 Python
Python urllib2运行过程原理解析
2020/06/04 Python
Python 程序报错崩溃后如何倒回到崩溃的位置(推荐)
2020/06/23 Python
HTML5 body设置全屏背景图片的示例代码
2020/12/08 HTML / CSS
教师职称自我鉴定
2014/02/12 职场文书
低碳生活的宣传标语
2014/06/23 职场文书
加强机关作风建设心得体会
2014/10/22 职场文书
2015年五一劳动节活动总结
2015/02/09 职场文书
小兵张嘎观后感
2015/06/03 职场文书
村党总支部公开承诺书2016
2016/03/25 职场文书
合理缓解职场压力,让你随时保持最佳状态!
2019/06/21 职场文书
Python爬虫中urllib3与urllib的区别是什么
2021/07/21 Python
SQL IDENTITY_INSERT作用案例详解
2021/08/23 MySQL
Python语法学习之进程的创建与常用方法详解
2022/04/08 Python