在vue项目创建好后
会生成三个env文件(.env、.env.development、.env.production)
(.env文件中变量会被)
.env:在项目启动后默认会加载
.env.development:在使用npm run serve 命令时会默认加载
.env 无论开发环境还是生产环境都会加载的配置文件
(.env文件中与.env.XXX中声明的名相同时,会使用.env.XXX中声明变量的值)
(如使用npm run serve 会自动加载.env与.env.development中的变量,.env文件中与.env.development中声明的名相同时,会使用.env.development中声明变量的值)
.env.development 开发环境加载的配置文件
.env.production 生产环境加载的配置文件
.env中变量使用,变量名声明为VUE_APP_*格式
console.log(process.env.VUE_APP_SECRET)
除了 VUE_APP_*
变量之外,在你的应用代码中始终可用的还有两个特殊的变量:
NODE_ENV
- 会是"development"
、"production"
或"test"
中的一个。具体的值取决于应用运行的模式。BASE_URL
- 会和vue.config.js
中的publicPath
选项相符,即你的应用会部署到的基础路径。
在package.json中可以选择使用加载哪个配置的变量(不知道该咋描述,自行体会吧)
"scripts": {
//会加载.env.development文件中的变量
"serve": "vue-cli-service serve",
//会加载.env.production文件中的变量
"build": "vue-cli-service build",
//会加载.env.ceshi文件中的变量
"build:ceshi": "vue-cli-service build --mode ceshi"
"test:unit": "vue-cli-service test:unit",
"lint": "vue-cli-service lint",
"lint:nofix": "vue-cli-service lint --no-fix",
"postinstall": "patch-package"
},
//--mode 名称
//代表加载的哪个.env文件的变量
注意:声明的变量值 为字符串,需要存对象什么的,使用的时候记得使用JSON.parse()转一下