基于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 相关文章推荐
破除一些网站复制、右键限制
Nov 04 Javascript
JS实现self的resend
Jul 22 Javascript
JavaScript 参数中的数组展开 [译]
Sep 21 Javascript
javascript中setAttribute()函数使用方法及兼容性
Jul 19 Javascript
深入分析node.js的异步API和其局限性
Sep 05 Javascript
最常见的左侧分类菜单栏jQuery实现代码
Nov 28 Javascript
读Javascript高性能编程重点笔记
Dec 21 Javascript
angularjs点击图片放大实现上传图片预览
Feb 24 Javascript
jQuery选择器之属性过滤选择器详解
Sep 28 jQuery
JS实现换肤功能的方法实例详解
Jan 30 Javascript
对layui中的onevent 和event的使用详解
Sep 06 Javascript
Angular性能优化之第三方组件和懒加载技术
May 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
DOMXML函数笔记
2006/10/09 PHP
php $_ENV为空的原因分析
2009/06/01 PHP
php下将XML转换为数组
2010/01/01 PHP
PHP图片处理类 phpThumb参数用法介绍
2012/03/11 PHP
php编写的抽奖程序中奖概率算法
2015/05/14 PHP
百万级别知乎用户数据抓取与分析之PHP开发
2015/09/28 PHP
js对数字的格式化使用说明
2011/01/12 Javascript
js,jQuery 排序的实现代码,网页标签排序的实现,标签排序
2011/04/27 Javascript
获取鼠标在div中的相对位置的实现代码
2013/12/30 Javascript
标题过长使用javascript按字节截取字符串
2014/04/24 Javascript
JavaScript数值转换的三种方式总结
2014/07/31 Javascript
学习javascript面向对象 javascript实现继承的方式
2016/01/04 Javascript
悬浮广告方法日常收集整理
2016/03/18 Javascript
深入理解js数组的sort排序
2016/05/28 Javascript
JavaScript 限制文本框不可输入英文单双引号的方法
2016/12/20 Javascript
js实现用户输入的小写字母自动转大写字母的方法
2017/01/21 Javascript
JavaScript异步上传图片文件的实例代码
2017/07/04 Javascript
jQuery UI 实例讲解 - 日期选择器(Datepicker)
2017/09/18 jQuery
在 webpack 中使用 ECharts的实例详解
2018/02/05 Javascript
在create-react-app中使用css modules的示例代码
2018/07/31 Javascript
2019 年编写现代 JavaScript 代码的5个小技巧(小结)
2019/01/15 Javascript
vue-列表下详情的展开与折叠案例
2020/07/28 Javascript
JavaScript实现4位随机验证码的生成
2021/01/28 Javascript
[04:40]DOTA2-DPC中国联赛1月26日Recap集锦
2021/03/11 DOTA
Python 12306抢火车票脚本 Python京东抢手机脚本
2018/02/06 Python
Python 实现一行输入多个值的方法
2018/04/21 Python
使用python获取(宜宾市地震信息)地震信息
2019/06/20 Python
Python Web程序搭建简单的Web服务器
2019/07/31 Python
Python中有几个关键字
2020/06/04 Python
瑞典网上购买现代和复古家具:Reforma
2019/10/21 全球购物
可靠的数据流传输TCP
2016/03/15 面试题
线程问题:wait()方法是定义在哪个类里面
2015/07/07 面试题
毕业生动漫设计求职信
2013/10/11 职场文书
企业元宵节主持词
2014/03/25 职场文书
授权委托书格式范文
2014/08/02 职场文书
销售经理工作检讨书
2015/02/19 职场文书