vue-cli3.0 环境变量与模式配置方法


Posted in Javascript onNovember 08, 2018

vue-cli3.0移除了配置文件目录: config和build文件夹。可以说是非常的精简了,那移除了配置文件目录后如何自定义配置环境变量和模式呢?

为什么需要配置环境变量和模式呢?

所有方法肯定是来源于现实的需求。在一个产品的前端开发过程中,一般来说会经历本地开发、测试脚本、开发自测、测试环境、预上线环境,然后才能正式的发布。对应每一个环境可能都会有所差异,比如说服务器地址、接口地址、websorket地址…… 等等。在各个环境切换的时候,就需要不同的配置参数,所以就可以用环境变量和模式,来方便我们管理。

环境变量

cli-3.0总共提供了四种方式来制定环境变量:

1.在根目录添加.env文件,配置所有情况下都会用到的配置(不知道这个存在的意义,所有的都需要的也就不需要配置了吧)。

2.在根目录添加.env.local 文件,配置所有情况下都会用到的配置,与.env的区别是只会在本地,该文件不会被git跟踪。

3.在根目录添加.env.[mode] 文件,配置对应某个模式下的配置,比如:.env.development来配置开发环境的配置。

4.在根目录添加.env.[mode].local文件,配置对应某个模式下的配置,与.env.[mode]的区别也只是会在本地生效,该文件不会被git跟踪。

在文件中,我们只需要以key=value的方式就可以设置变量了。

例如:

FOO=bar
VUE_APP_SECRET=secret

环境变量的使用

设置完环境变量之后就可以在我们的项目中使用这两个变量了。不过还需要注意的是在项目的不同地方使用,限制也不一样。

1.在项目中,也就是src中使用环境变量的话,必须以VUE_APP_开头。例如我们可以在main.js中直接输出:console.log(process.env.VUE_APP_SECRET)

2.在webpack配置中使用,没什么限制,可以直接通过process.env.XXX来使用

3.在public/index.html中使用的:分三类:(没怎么用过)

<%= VAR %> 用于非转换插值 例如:`<link rel="shortcut icon" href="<%= BASE_URL %>favicon.ico" rel="external nofollow" >`
 <%- VAR %> 用于HTML转义插值
 <% expression %> 用于JavaScript控制流

模式

模式是Vue CLI项目中的一个重要概念。默认情况下,Vue CLI项目中有三种模式:

1.development:在vue-cli-service serve下,即开发环境使用

2.production:在vue-cli-service build 和vue-cli-service test:e2e下,即正式环境使用

3.test: 在vue-cli-service test:unit下使用

另外,如果你想要修改模式下默认的环境变量的话可以通过--mode来实现,例如:

 "dev-build": "vue-cli-service build --mode development"

有环境变量就能完成我们的需求了,为什么需要有模式的存在,这里我没查到详细的文档,个人认为模式是为了提供给第三方的插件一个辨识。例如vuex可以根据模式的不同,在development自动注入devtoolPlugin插件,利于开发,而在production中检测到错误不会进行console。

举例

说完了概念,可能还是比较模糊,可以试着添加一个stage环境,用来模拟预上线。

首先在package.json添加一种类型,并修改默认环境变量为stage环境变量

vue-cli3.0 环境变量与模式配置方法

在根目录下创建.env.stage文件,来声明变量:

vue-cli3.0 环境变量与模式配置方法

vue-cli3.0 环境变量与模式配置方法

这里声明的NODE_ENV = ‘production'用来表示这是生产环境。VUE_APP_CURRENTMODE为项目变量,outputDir为除数打包后文件的地址。
在vue.config.js中使用环境变量,制定输出文件为环境变量配置的文件:

vue-cli3.0 环境变量与模式配置方法

最后执行命令yarn stage能看到根目录下生成了stage文件:

vue-cli3.0 环境变量与模式配置方法

这样我们就配置完了stage环境。详细的项目地址可以参考:以vue-cli3.0为基础,结合vue-router、vuex、axios、iview组件库搭建一个工程化前端demo

参考文档:Environment Variables and Modes

总结

以上所述是小编给大家介绍的vue-cli3.0 环境变量与模式配置方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JQuery调webservice实现邮箱验证(检测是否可用)
May 21 Javascript
文本框文本自动补全效果示例分享
Jan 19 Javascript
js 实现的可折叠留言板(附源码下载)
Jul 01 Javascript
防止登录页面出现在frame中js代码
Jul 22 Javascript
jquery mobile开发常见问题分析
Jan 21 Javascript
WEB前端实现裁剪上传图片功能
Oct 17 Javascript
关于webuploader插件使用过程遇到的小问题
Nov 07 Javascript
angularjs+bootstrap实现自定义分页的实例代码
Jun 19 Javascript
彻底搞懂JavaScript中的apply和call方法(必看)
Sep 18 Javascript
学习React中ref的两个demo示例
Aug 14 Javascript
vue如何解决循环引用组件报错的问题
Sep 22 Javascript
详解JavaScript作用域 闭包
Jul 29 Javascript
详解如何创建并发布一个 vue 组件
Nov 08 #Javascript
webpack开发环境和生产环境的深入理解
Nov 08 #Javascript
webpack 开发和生产并行设置的方法
Nov 08 #Javascript
JS动画实现回调地狱promise的实例代码详解
Nov 08 #Javascript
深入解析ES6中的promise
Nov 08 #Javascript
vue中promise的使用及异步请求数据的方法
Nov 08 #Javascript
node使用Mongoose类库实现简单的增删改查
Nov 08 #Javascript
You might like
强制PHP命令行脚本单进程运行的方法
2014/04/15 PHP
字符串长度函数strlen和mb_strlen的区别示例介绍
2014/09/09 PHP
全面解读PHP的人气开发框架Laravel
2015/10/15 PHP
PHP设计模式之建造者模式定义与用法简单示例
2018/08/13 PHP
php使用mysqli和pdo扩展,测试对比连接mysql数据库的效率完整示例
2019/05/09 PHP
IE6、IE7中获取Button元素的值的bug说明
2011/08/28 Javascript
jQuery插件实现屏蔽单个元素使用户无法点击
2013/04/12 Javascript
Nodejs实现多房间简易聊天室功能
2017/06/20 NodeJs
Nodejs使用Mongodb存储与提供后端CRD服务详解
2018/09/04 NodeJs
JS删除对象中某一属性案例详解
2020/09/08 Javascript
vue中配置scss全局变量的步骤
2020/12/28 Vue.js
[45:32]Liquid vs LGD 2018国际邀请赛淘汰赛BO3 第二场 8.23
2018/08/24 DOTA
Python抽象类的新写法
2015/06/18 Python
Python 中的 else详解
2016/04/23 Python
遗传算法之Python实现代码
2017/10/10 Python
python中 logging的使用详解
2017/10/25 Python
获取Django项目的全部url方法详解
2017/10/26 Python
Python栈算法的实现与简单应用示例
2017/11/01 Python
Tensorflow的可视化工具Tensorboard的初步使用详解
2018/02/11 Python
使用Python横向合并excel文件的实例
2018/12/11 Python
详解Python进阶之切片的误区与高级用法
2018/12/24 Python
你应该知道的Python3.6、3.7、3.8新特性小结
2020/05/12 Python
详解CSS3新增的背景属性
2019/12/25 HTML / CSS
解决img标签上下出现间隙的方法
2016/12/14 HTML / CSS
爱尔兰家电数码商城:Currys PC World爱尔兰
2016/07/23 全球购物
英语专业毕业生自荐信范文
2013/12/31 职场文书
迟到检讨书大全
2014/01/25 职场文书
洗发露广告词
2014/03/14 职场文书
工伤事故赔偿协议书范文
2014/09/24 职场文书
党的群众路线教育实践活动个人对照检查材料(教师)
2014/11/04 职场文书
精神文明建设先进个人事迹材料
2014/12/24 职场文书
小学教师工作总结2015
2015/04/07 职场文书
小学家长意见怎么写
2015/06/03 职场文书
投诉书范文
2015/07/02 职场文书
MySQL实现配置主从复制项目实践
2022/03/31 MySQL
HTML中link标签属性的具体用法
2023/05/07 HTML / CSS