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 18 Vue.js
vue 插槽简介及使用示例
Nov 19 Vue.js
vue绑定class的三种方法
Dec 24 Vue.js
Vue仿百度搜索功能
Dec 28 Vue.js
Vue项目打包部署到apache服务器的方法步骤
Feb 01 Vue.js
Vue实现圆环进度条的示例
Feb 06 Vue.js
Vue基本指令实例图文讲解
Feb 25 Vue.js
vue中axios封装使用的完整教程
Mar 03 Vue.js
如何理解Vue前后端数据交互与显示
May 10 Vue.js
Vue过滤器(filter)实现及应用场景详解
Jun 15 Vue.js
vue实现可以快进后退的跑马灯组件
Apr 08 Vue.js
vue项目如何打包之项目打包优化(让打包的js文件变小)
Apr 30 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中使用Oracle数据库(1)
2006/10/09 PHP
深入php中var_dump方法的使用详解
2013/06/24 PHP
PHP面向对象程序设计实例分析
2016/01/26 PHP
一个简单的php MVC留言本实例代码(必看篇)
2016/09/22 PHP
AngularJS 使用 UI Router 实现表单向导
2016/01/29 Javascript
jQuery on()方法绑定动态元素的点击事件实例代码浅析
2016/06/16 Javascript
AngularJS 整理一些优化的小技巧
2016/08/18 Javascript
js代码延迟一定时间后执行一个函数的实例
2017/02/15 Javascript
微信小程序 下拉列表的实现实例代码
2017/03/08 Javascript
JavaScript实现form表单的多文件上传
2020/03/27 Javascript
通过webpack引入第三方库的方法
2018/07/20 Javascript
详解使用jest对vue项目进行单元测试
2018/09/07 Javascript
Vue项目pdf(base64)转图片遇到的问题及解决方法
2018/10/19 Javascript
如何测量vue应用运行时的性能
2019/06/21 Javascript
如何阻止小程序遮罩层下方图层滚动
2019/09/05 Javascript
JS数组属性去重并校验重复数据
2020/01/10 Javascript
分析在Python中何种情况下需要使用断言
2015/04/01 Python
Python多线程编程(四):使用Lock互斥锁
2015/04/05 Python
Python中对元组和列表按条件进行排序的方法示例
2015/11/10 Python
Python 爬虫学习笔记之单线程爬虫
2016/09/21 Python
python寻找list中最大值、最小值并返回其所在位置的方法
2018/06/27 Python
python把1变成01的步骤总结
2019/02/27 Python
Python使用pyexecjs代码案例解析
2020/07/13 Python
英国最大的奢侈品零售网络商城:Flannels
2016/09/16 全球购物
美国女士内衣在线折扣商店:One Hanes Place
2019/03/24 全球购物
介绍一下Java中标识符的命名规则
2014/02/03 面试题
机械设计职业生涯规划书
2013/12/27 职场文书
广告创意求职信
2014/03/17 职场文书
公安学专业求职信
2014/07/27 职场文书
幼儿园迎国庆65周年活动策划方案
2014/09/16 职场文书
在人间读书笔记
2015/06/30 职场文书
2015年幼儿园师德师风建设工作总结
2015/10/23 职场文书
2016大学生毕业实习心得体会
2016/01/23 职场文书
mysql优化
2021/04/06 MySQL
使用nginx配置访问wgcloud的方法
2021/06/26 Servers
Docker安装MySql8并远程访问的实现
2022/07/07 Servers