资讯专栏INFORMATION COLUMN

vue-cli3环境变量与分环境打包

gotham / 1573人阅读

摘要:一般情况下项目有三个默认模式模式用于模式用于和模式用于模式不等同于,一个模式可以包含多个环境变量。你可以通过为文件增加后缀来设置某个模式下特有的环境变量。

第一步 : 了解环境变量概念

我们可以根目录中的下列文件来指定环境变量:

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

环境变量文件只包含环境变量的“键=值”对:

FOO=bar
VUE_APP_SECRET=secret // 只有VUE_APP_开头的环境变量可以在项目代码中直接使用

除了 自定义的VUE_APP_* 变量之外,在你的应用代码中始终可用的还有两个特殊的变量:

NODE_ENV - 会是 "development"、"production" 或 "test"
中的一个。具体的值取决于应用运行的模式。

BASE_URL - 会和 vue.config.js 中的 publicPath 选项相符,即你的应用会部署到的基础路径。

为一个特定模式准备的环境文件的 (例如 .env.production) 将会比一般的环境文件 (例如 .env) 拥有更高的优先级。

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

development 模式用于 vue-cli-service serve

production 模式用于 vue-cli-service build 和 vue-cli-service test:e2e

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)

理解指令 , 模式 , 环境变量之间的关系
我们在项目中的package.json经常能看见以下这样的指令

在一个 Vue CLI 项目中,@vue/cli-service 安装了一个名为 vue-cli-service 的命令。你可以在 npm scripts 中以 vue-cli-service、或者从终端中以 ./node_modules/.bin/vue-cli-service 访问这个命令。
vue-cli-service serve

用法:vue-cli-service serve [options] [entry]
选项:
  --open    在服务器启动时打开浏览器
  --copy    在服务器启动时将 URL 复制到剪切版
  --mode    指定环境模式 (默认值:development)
  --host    指定 host (默认值:0.0.0.0)
  --port    指定 port (默认值:8080)
  --https   使用 https (默认值:false)

vue-cli-service build

用法:vue-cli-service build [options] [entry|pattern]

选项:
  --mode        指定环境模式 (默认值:production)
  --dest        指定输出目录 (默认值:dist)
  --modern      面向现代浏览器带自动回退地构建应用
  --target      app | lib | wc | wc-async (默认值:app)
  --name        库或 Web Components 模式下的名字 (默认值:package.json 中的 "name" 字段或入口文件名)
  --no-clean    在构建项目之前不清除目标目录
  --report      生成 report.html 以帮助分析包内容
  --report-json 生成 report.json 以帮助分析包内容
  --watch       监听文件变化

以上是两个常用的cli指令 , 他们默认对应的分别是development和production模式 , 如果还想了解其他指令 , 可以访问: https://cli.vuejs.org/zh/guid... CLI 服务

那么接下来 , 我们就开始创建一个用于打包测试环境的模式;

修改package.json
添加一行命令

"test": "vue-cli-service build --mode test"

添加.env.test文件
在项目根路径创建.env.test文件,内容为

NODE_ENV="production"  //表明这是生产环境(需要打包)
VUE_APP_CURRENTMODE="test" // 表明生产环境模式信息
VUE_APP_BASEURL="http://***.****.com:8000" // 测试服务器地址

修改项目中的api接口文件
在我的项目中,一般会创建一个api.js 来管理所有的接口url
因为我们在本地开发环境中是通过代理来连接服务器的,所以将url写成这

`${baseUrl}/apis/v1/login`,

在文件开头通过环境变量改变baseUrl

let baseUrl = "";
if (process.env.NODE_ENV == "development") {
  baseUrl = "" 
} else if (process.env.NODE_ENV == "production") {
  baseUrl = process.env.VUE_APP_BASEURL
} else {
  baseUrl = "" 
}

当需要为测试环境进行打包的时候 , 我们只需要运行下面指令进行打包

npm run test

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/101701.html

相关文章

  • vue-cli3 配置开发-测试环境

    摘要:实现输入一行命令,执行两条指令,分别打包线上生产环境和线上测试环境的代码。这样配置好之后,只要执行,它会自动先执行正式环境构建打包,完成之后再自动执行测试环境的构建打包,是方便接着再配置自动压缩,这里就需要使用到一个的插件。 需求 首先介绍一下本项目的背景,是基于 vue-cli3.1.1 的单页应用,目前测试环境和生产环境都在线上,并且都在同一个域名下,其中生产环境部署在根目录下,测...

    Scott 评论0 收藏0
  • 用cordova+vue-cli 打包成 android apk 过程和路径问题

    摘要:简介最近用框架写安卓版,本来打算用打包成文件即可,但发现配置起来复杂,还不如自己搭建环境,用工具提供的命令在终端实现,下面介绍遇到的问题及解决。 简介:最近用vue-cli框架写安卓版APP,本来打算用Hbuilder打包成.apk文件即可,但发现配置起来复杂,还不如自己搭建环境,用cordova工具提供的命令在终端实现,下面介绍遇到的问题及解决。一、打包过程首先要有node环境,然后...

    LucasTwilight 评论0 收藏0
  • 用cordova+vue-cli 打包成 android apk 过程和路径问题

    摘要:简介最近用框架写安卓版,本来打算用打包成文件即可,但发现配置起来复杂,还不如自己搭建环境,用工具提供的命令在终端实现,下面介绍遇到的问题及解决。 简介:最近用vue-cli框架写安卓版APP,本来打算用Hbuilder打包成.apk文件即可,但发现配置起来复杂,还不如自己搭建环境,用cordova工具提供的命令在终端实现,下面介绍遇到的问题及解决。一、打包过程首先要有node环境,然后...

    Forest10 评论0 收藏0
  • 揭秘vue——vue-cli3全面配置

    摘要:中可以使用注入变量访问环境变量中的配置信息向全局样式传入共享的全局变量在中引用添加兼容在中添加配置完整配置持续更新中揭秘系列 目录 √ 配置多环境变量 √ 配置基础 vue.config.js √ 配置 proxy 跨域 √ 修复 HMR(热更新)失效 √ 修复 Lazy loading routes Error: Cyclic dependency √ 添加别名alias √ 压缩...

    hatlonely 评论0 收藏0

发表评论

0条评论

gotham

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<