基于vue cli 通过命令行传参实现多环境配置

作者:obliviousSing 时间:2024-04-29 13:08:30 

大多数项目都有生产环境和开发环境,一般情况下应该够了,但是有时候还需要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://www.aspxhome.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 通过命令行传参实现多环境配置网站的支持!

来源:https://juejin.im/post/5b457dd3f265da0f51404741

标签:vue,命令行
0
投稿

猜你喜欢

  • Python如何自动获取目标网站最新通知

    2021-07-14 18:18:16
  • asp利用XMLHTTP无刷新自动更新数据

    2007-08-23 13:16:00
  • 细化解析:SQL Server数据库的集群设计

    2009-02-05 15:59:00
  • Python排序搜索基本算法之插入排序实例分析

    2023-12-28 14:20:25
  • 在python下实现word2vec词向量训练与加载实例

    2022-06-12 23:49:05
  • python深度学习tensorflow卷积层示例教程

    2021-04-02 22:59:13
  • 在CentOS上MySQL数据库服务器配置方法

    2024-01-19 07:01:21
  • pandas通过字典生成dataframe的方法步骤

    2023-04-19 14:52:37
  • jupyter notebook快速入门及使用详解

    2023-07-17 07:48:57
  • 开启Django博客的RSS功能的实现方法

    2022-06-16 02:02:04
  • oracle数据库sql的优化总结

    2024-01-23 16:05:11
  • golang 两个go程轮流打印一个切片的实现

    2024-02-12 09:11:29
  • Pytorch 多块GPU的使用详解

    2021-01-21 09:19:09
  • 对python使用http、https代理的实例讲解

    2022-03-13 00:03:08
  • Python语言规范之Pylint的详细用法

    2022-11-26 03:12:25
  • PyTorch深度学习模型的保存和加载流程详解

    2023-07-10 04:58:33
  • 浅谈Python实时检测CPU和GPU的功耗

    2021-06-11 17:05:58
  • NumPy进行统计分析

    2023-09-21 00:16:15
  • MySQL忘记密码恢复密码的实现方法

    2024-01-19 08:55:14
  • 模型训练时GPU利用率太低的原因及解决

    2021-02-05 22:22:07
  • asp之家 网络编程 m.aspxhome.com