vue cli中环境变量和模式
Posted kanaliya
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue cli中环境变量和模式相关的知识,希望对你有一定的参考价值。
环境变量配置
环境变量可以在以下文件中配置:
.env # 在所有的环境中被载入
.env.local # 在所有的环境中被载入,但会被 git 忽略
.env.[mode] # 只在指定的模式中被载入
.env.[mode].local # 只在指定的模式中被载入,但会被 git 忽略
(.local优先于.env生效)
文件内部使用键值对的方式对变量进行配置
被载入的变量将会对 vue-cli-service 的所有命令、插件和依赖可用,同时为一个特定模式准备的环境文件的 (例如 .env.production) 将会比一般的环境文件 (例如 .env) 拥有更高的优先级。
模式
默认情况下,一个 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
注意模式不同于NODE_ENV
,一个模式可以包含多个环境变量,即每个模式都会将NODE_ENV
的值设置为模式的名称——比如在development 模式下NODE_ENV
的值会被设置为"development"。
可以通过为 .env 文件增加后缀来设置某个模式下特有的环境变量。比如,如果在项目根目录创建一个名为 .env.development 的文件,那么在这个文件里声明过的变量就只会在 development 模式下被载入。
也可以通过传递--mode
选项参数为命令行覆写默认的模式。例如,如果想要在构建命令中使用开发环境变量,只需要在package.json脚本中加入:
"dev-build": "vue-cli-service build --mode development",
变量
只有以 VUE_APP_ 开头的变量会被 webpack.DefinePlugin 静态嵌入到客户端侧的包中。你可以在应用的代码中这样访问它们:
console.log(process.env.VUE_APP_SECRET)
在构建过程中,process.env.VUE_APP_SECRET 将会被相应的值所取代。在VUE_APP_SECRET=secret
的情况下,它会被替换为 "secret"。
除VUE_APP_*变量之外,在应用代码中始终可用的还有两个特殊的变量:
NODE_ENV - 会是 "development"、"production" 或 "test" 中的一个。具体的值取决于应用运行的模式。
BASE_URL - 会和 vue.config.js 中的 publicPath 选项相符,即你的应用会部署到的基础路径。
注:所有解析出来的环境变量都可以在 public/index.html 中以HTML插值的方式(<%=...%>)使用
以上是关于vue cli中环境变量和模式的主要内容,如果未能解决你的问题,请参考以下文章