时间:2021-05-26
大多数项目都有生产环境和开发环境,一般情况下应该够了,但是有时候还需要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.jb51.net/article/138055.htm
我们首先在根目录下面创建一个vue.config.js文件,如图
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的文件
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 localUrltry { 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
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 ,页面打印如下:
再啰嗦下,process.env.NODE_ENV是@vue/cli提供的,貌似有三个值(development,production,test),
你运行 npm run serve 得到的就是development
你运行 npm run build 得到的就是production
你运行 npm run test 得到的就是test (我没试过)
我默认打包是打包生产环境,当然你也可以输入参数打包其他环境
总结
以上所述是小编给大家介绍的基于vue cli 通过命令行传参实现多环境配置,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
基于webpack的配置调试使用Vue-cli命令行工具初始化基于wabpack模板的项目的命令语法:npminstall-g@vue/cli#全局安装vue-
CiscoIOS的概念 IOS配置通常是通过基于文本的命令行接口(CommandLineInterface,CLI)进行的。 Cisco的网际操作系统(
搭建vue的开发环境:1、必须要安装nodejs2、搭建vue的开发环境,安装vue的脚手架工具官方命令行工具npminstall--globalvue-cli
vue官方提供的命令行工具vue-cli,能够快速搭建单页应用。默认一个页面入口index.html,那么,如果我们需要多页面该如何配置,实际上也不复杂假设要新
前言假设已经有一个通过vue-cli3脚手架构建的vue项目命令行安装Typescriptnpminstall--save-devtypescriptnpmin