背景

在我的项目部署时,咱们须要在测试环境和生产环境应用不同的变量。
vue-cli提供了vue-cli-service build打包命令,然而vue-cli-service build默认的环境变量值则为production。那咱们通过npm run build打包构建,想要实现不同环境应用不同变量,临时不能实现。

介绍

vue-cli生成我的项目时,在package.json中会设置:

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

vue-cli-service serve 命令会启动一个开发服务器,默认指定的环境模式为development。
vue-cli-service build 会在 dist/ 目录产生一个可用于生产环境的包,带有 JS/CSS/HTML 的压缩,和为更好的缓存而做的主动的vendor chunk splitting。

环境变量和模式

在我的项目的根目录下咱们能够创立不同模式的文件:

.env                # 在所有的环境中被载入.env.local          # 在所有的环境中被载入,但会被 git 疏忽.env.[mode]         # 只在指定的模式中被载入.env.[mode].local   # 只在指定的模式中被载入,但会被 git 疏忽

一般来说,咱们会存在本地环境、测试环境、线上环境,那咱们就须要创立三个模式文件。

  • .env.development开发环境模式
// 环境变量NODE_ENV=development// 以 VUE_APP_ 结尾的变量会被 webpack.DefinePlugin 动态嵌入到客户端侧的包中VUE_APP_ENV = 'development'
  • .env.test测试环境模式
// 环境变量(这里的环境变量是跟打包无关的,production则会进行压缩代码等,真正跟每个环境无关的变量是上面以VUE_APP结尾的变量)NODE_ENV=production// 以 VUE_APP_ 结尾的变量会被 webpack.DefinePlugin 动态嵌入到客户端侧的包中VUE_APP_ENV = 'test'
  • .env.production线上环境模式
// 环境变量NODE_ENV=production// 以 VUE_APP_ 结尾的变量会被 webpack.DefinePlugin 动态嵌入到客户端侧的包中VUE_APP_ENV = 'production'

配置不同模式

部署时,构建打包执行npm run build,则会执行vue-cli-service build,默认模式为production,对应.env.production文件,取此文件中的环境变量。

想要配置测试环境,须要在scripts下减少脚本:

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

测试环境打包构建时,执行npm run build-test即可。

index.html应用环境变量

index.html中可通过<%= process.env.VUE_APP_xxx %>的形式获取不同模式下配置的环境变量。