vue项目多环境配置(.env)的实现


Posted in Vue.js onJuly 21, 2021

没接触多环境配置前,感觉好高大上,真正操作后感觉也就那么回事,在此把自己遇到的问题和解决方案叙述一下,有不对的地方欢迎各位大佬指出。

什么是多环境配置,为什么要多环境配置?

最常见的多环境配置,就是开发环境配置,和生产环境配置(也就是上线的配置),很多情况下我们开发环境下的域名,和一些配置项,和我们生产模式下的不同,这个时候就需要我们进行多环境配置,不然每次发版都要改一波数据多麻烦。另一种情况就是你两个项目是用的一套代码,但是最后又要分别打成不同的包,那么这个时候多环境配置就大大提升了开发效率。

.env 文件配置到哪里

.env文件配置在你项目的根目录里面和package.json同级如下图。

vue项目多环境配置(.env)的实现

.env文件如何配置,配置多少个?

.env文件如何命名?
最开始我在网上查的时候好多博主说名字必须命名成
.env.development 开发环境下的配置文件
.env.production 生产环境下的配置文件
其实不是的,如果你配置的是开发环境和生产环境那么这样命名,无可厚非,但是你如果是多项目公用代码,这样命名就有点驴头不对马嘴。所以这块的命名格式只需要文件开头为.env即可,后面的名字你想怎样都可以

.env文件的配置

这块就是你想用什么东西就配置什么东西,打个比方我想在项目全局拿到一个名字,那你就直接.env里面配置就ok了,下面我会详细叙述如何取值。

npm run serve 或者npm run build 的时候,会默认走.env的配置

图示:

vue项目多环境配置(.env)的实现

//这块只需要 VUE_APP_*** 以这样的形式命名就ok了,后面大写还是小写这块看你心情都可以。
VUE_APP_NAME = '娄渊洋'
VUE_APP_HTTPS = 'http://www.louhc.com/'
VUE_APP_ABBREVIATION = 'louhc'
VUE_APP_LOGO = 'louhc'

默认的.env文件配置好后,我们接着配置有特殊需求的.env文件,比如我想让在另一种环境下使用 其他的名字。例如 .env.bsy文件 .bsy是我随便写的名字这块可以自定义。

//这块只需要 VUE_APP_*** 以这样的形式命名就ok了,后面大写还是小写这块看你心情都可以。
VUE_APP_NAME = '白衫云'
VUE_APP_HTTPS = 'http://www.louhc.com:82/'
VUE_APP_ABBREVIATION = 'bsy'
VUE_APP_LOGO = 'bsy'

依次类推你想配置多少个都可以
.env文件配好后我们就该配置运行环境了

如何配置运行环境

找到package.json文件,如下图

vue项目多环境配置(.env)的实现

build: 和 serve: 后面跟的名字就是你随便起的名字一定要对应上,这在运行的时候才能找到相应的配置项。

"scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "build:bsy": "vue-cli-service build --mode bsy",
    "build:kthz": "vue-cli-service build --mode kthz",
    "serve:bsy": "vue-cli-service serve --mode bsy",
    "serve:kthz": "vue-cli-service serve --mode kthz",
  },

再次多说一点:.env是默认配置项,当运行环境配置项的时候,会将默认配置项和运行的环境配置项融合,在参数相同的情况下,会以环境配置项为主,简单来说就是,默认配置项存在,环境配置项也存在,这个时候运行哪个环境配置项,就以哪个环境配置项的值为准,如果默认配置项存在,环境配置项不存在,那么运行环境配置项的时候同样也可以拿到默认配置项的值。

如何获取全局配置项的值

例子:如何我想在js中拿到 VUE_APP_NAME = ‘娄渊洋',那么这直接在你想赋值的地方写上这行代码即可 process.env.VUE_APP_NAME

console.log(process.env.VUE_APP_NAME)// 默认环境下打印的就是娄渊洋 bsy 环境下就是 白衫云

如果我们项在html中使用全局配置项的值,需要我们先在return 中赋值一下,然后 才可以通过 {{}},拿到你想要用的值。

如何运行环境

运行默认环境 npm run serve
运行指定的环境 npm run serve:bsy
默认环境打包 npm run build
指定环境打包 npm run build:bsy
只需切换不同的环境名即可

到此这篇关于vue项目多环境配置(.env)的实现的文章就介绍到这了,更多相关vue 多环境配置内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
解决vue页面刷新,数据丢失的问题
Nov 24 Vue.js
vue祖孙组件之间的数据传递案例
Dec 07 Vue.js
vue 实现基础组件的自动化全局注册
Dec 25 Vue.js
vuex的使用步骤
Jan 06 Vue.js
如何在vue-cli中使用css-loader实现css module
Jan 07 Vue.js
Vue-router编程式导航的两种实现代码
Mar 04 Vue.js
Vue3 Composition API的使用简介
Mar 29 Vue.js
vue.js Router中嵌套路由的实用示例
Jun 27 Vue.js
SSM VUE Axios详解
Oct 05 Vue.js
vue实现Toast组件轻提示
Apr 10 Vue.js
vue修饰符.capture和.self的区别
Apr 22 Vue.js
vue el-table实现递归嵌套的示例代码
Aug 14 Vue.js
Vue Element-ui表单校验规则实现
Jul 09 #Vue.js
Vue3.0中Ref与Reactive的区别示例详析
Jul 07 #Vue.js
Vue项目打包、合并及压缩优化网页响应速度
idea编译器vue缩进报错问题场景分析
Vue实现导入Excel功能步骤详解
Vue图片裁剪组件实例代码
vue3中provide && inject的使用
Jul 01 #Vue.js
You might like
PHP获取文件后缀名的三个函数
2012/10/15 PHP
php第一次无法获取cookie问题处理
2014/12/15 PHP
php用户注册时常用的检验函数实例总结
2014/12/22 PHP
大家在抢红包,程序员在研究红包算法
2015/08/31 PHP
PHP实现的最大正向匹配算法示例
2017/12/19 PHP
jquery操作select option 的代码小结
2011/06/21 Javascript
统计jQuery中各字符串出现次数的工具
2012/05/03 Javascript
Redis基本知识、安装、部署、配置笔记
2015/03/05 Javascript
jQuery实现仿QQ空间装扮预览图片的鼠标提示效果代码
2015/10/30 Javascript
js无法获取到html标签的属性的解决方法
2016/07/26 Javascript
JavaScript下拉菜单功能实例代码
2017/03/01 Javascript
select自定义小三角样式代码(实用总结)
2017/08/18 Javascript
详解Nuxt.js部署及踩过的坑
2018/08/07 Javascript
微信小程序使用swiper组件实现类3D轮播图
2018/08/29 Javascript
微信小程序按钮点击跳转页面详解
2019/05/06 Javascript
微信小程序 动态修改页面数据及参数传递过程详解
2019/09/27 Javascript
使用 Angular RouteReuseStrategy 缓存(路由)组件的实例代码
2019/11/01 Javascript
JS实现可视化音频效果的实例代码
2020/01/16 Javascript
Python Mysql自动备份脚本
2008/07/14 Python
Python列表计数及插入实例
2014/12/17 Python
python设计tcp数据包协议类的例子
2019/07/23 Python
python实现网站用户名密码自动登录功能
2019/08/09 Python
python如何解析复杂sql,实现数据库和表的提取的实例剖析
2020/05/15 Python
高考考python编程是真的吗
2020/07/20 Python
Python读取图像并显示灰度图的实现
2020/12/01 Python
Laura Mercier官网:彩妆大师罗拉玛斯亚的化妆品牌
2018/01/04 全球购物
节约粮食标语
2014/06/18 职场文书
教室布置标语
2014/06/26 职场文书
欢迎新生标语
2014/10/06 职场文书
土建技术员岗位职责
2015/04/11 职场文书
经营场所证明范本
2015/06/19 职场文书
2015年城管执法工作总结
2015/07/23 职场文书
医疗纠纷调解协议书
2015/08/06 职场文书
一些让Python代码简洁的实用技巧总结
2021/08/23 Python
python可视化大屏库big_screen示例详解
2021/11/23 Python
Spring this调用当前类方法无法拦截的示例代码
2022/03/20 Java/Android