摘要:一般情況下項(xiàng)目有三個(gè)默認(rèn)模式模式用于模式用于和模式用于模式不等同于,一個(gè)模式可以包含多個(gè)環(huán)境變量。你可以通過(guò)為文件增加后綴來(lái)設(shè)置某個(gè)模式下特有的環(huán)境變量。
第一步 : 了解環(huán)境變量概念
我們可以根目錄中的下列文件來(lái)指定環(huán)境變量:
.env # 在所有的環(huán)境中被載入 .env.local # 在所有的環(huán)境中被載入,但會(huì)被 git 忽略 .env.[mode] # 只在指定的模式中被載入 .env.[mode].local # 只在指定的模式中被載入,但會(huì)被 git 忽略
環(huán)境變量文件只包含環(huán)境變量的“鍵=值”對(duì):
FOO=bar VUE_APP_SECRET=secret // 只有VUE_APP_開(kāi)頭的環(huán)境變量可以在項(xiàng)目代碼中直接使用
除了 自定義的VUE_APP_* 變量之外,在你的應(yīng)用代碼中始終可用的還有兩個(gè)特殊的變量:
NODE_ENV - 會(huì)是 "development"、"production" 或 "test"
中的一個(gè)。具體的值取決于應(yīng)用運(yùn)行的模式。
BASE_URL - 會(huì)和 vue.config.js 中的 publicPath 選項(xiàng)相符,即你的應(yīng)用會(huì)部署到的基礎(chǔ)路徑。
為一個(gè)特定模式準(zhǔn)備的環(huán)境文件的 (例如 .env.production) 將會(huì)比一般的環(huán)境文件 (例如 .env) 擁有更高的優(yōu)先級(jí)。
模式概念:
模式是 Vue CLI 項(xiàng)目中一個(gè)重要的概念。一般情況下 Vue CLI 項(xiàng)目有三個(gè)默認(rèn)模式:
development 模式用于 vue-cli-service serve
production 模式用于 vue-cli-service build 和 vue-cli-service test:e2e
test 模式用于 vue-cli-service test:unit
模式不等同于 NODE_ENV,一個(gè)模式可以包含多個(gè)環(huán)境變量。也就是說(shuō),每個(gè)模式都將 NODE_ENV的值設(shè)置為模式的名稱(可重新賦值更改)——比如在 development 模式下 NODE_ENV 的值會(huì)被設(shè)置為 "development"。
你可以通過(guò)為 .env 文件增加后綴來(lái)設(shè)置某個(gè)模式下特有的環(huán)境變量。比如,如果你在項(xiàng)目根目錄創(chuàng)建一個(gè)名為 .env.development 的文件,那么在這個(gè)文件里聲明過(guò)的變量就只會(huì)在 development 模式下被載入。
你可以通過(guò)傳遞 --mode 選項(xiàng)參數(shù)為命令行覆寫(xiě)默認(rèn)的模式。例如,如果你想要在構(gòu)建命令中使用開(kāi)發(fā)環(huán)境變量,請(qǐng)?jiān)谀愕?package.json 腳本中加入:
"dev-build": "vue-cli-service build --mode development",
環(huán)境變量的使用 :
只有以 VUE_APP_ 開(kāi)頭的變量會(huì)被 webpack.DefinePlugin 靜態(tài)嵌入到客戶端側(cè)的包中(即在項(xiàng)目代碼中使用)。你可以在應(yīng)用的代碼中這樣訪問(wèn)它們:
console.log(process.env.VUE_APP_SECRET)
理解指令 , 模式 , 環(huán)境變量之間的關(guān)系
我們?cè)陧?xiàng)目中的package.json經(jīng)常能看見(jiàn)以下這樣的指令
在一個(gè) Vue CLI 項(xiàng)目中,@vue/cli-service 安裝了一個(gè)名為 vue-cli-service 的命令。你可以在 npm scripts 中以 vue-cli-service、或者從終端中以 ./node_modules/.bin/vue-cli-service 訪問(wèn)這個(gè)命令。
vue-cli-service serve
用法:vue-cli-service serve [options] [entry] 選項(xiàng): --open 在服務(wù)器啟動(dòng)時(shí)打開(kāi)瀏覽器 --copy 在服務(wù)器啟動(dòng)時(shí)將 URL 復(fù)制到剪切版 --mode 指定環(huán)境模式 (默認(rèn)值:development) --host 指定 host (默認(rèn)值:0.0.0.0) --port 指定 port (默認(rèn)值:8080) --https 使用 https (默認(rèn)值:false)
vue-cli-service build
用法:vue-cli-service build [options] [entry|pattern] 選項(xiàng): --mode 指定環(huán)境模式 (默認(rèn)值:production) --dest 指定輸出目錄 (默認(rèn)值:dist) --modern 面向現(xiàn)代瀏覽器帶自動(dòng)回退地構(gòu)建應(yīng)用 --target app | lib | wc | wc-async (默認(rèn)值:app) --name 庫(kù)或 Web Components 模式下的名字 (默認(rèn)值:package.json 中的 "name" 字段或入口文件名) --no-clean 在構(gòu)建項(xiàng)目之前不清除目標(biāo)目錄 --report 生成 report.html 以幫助分析包內(nèi)容 --report-json 生成 report.json 以幫助分析包內(nèi)容 --watch 監(jiān)聽(tīng)文件變化
以上是兩個(gè)常用的cli指令 , 他們默認(rèn)對(duì)應(yīng)的分別是development和production模式 , 如果還想了解其他指令 , 可以訪問(wèn): https://cli.vuejs.org/zh/guid... CLI 服務(wù)
那么接下來(lái) , 我們就開(kāi)始創(chuàng)建一個(gè)用于打包測(cè)試環(huán)境的模式;
修改package.json
添加一行命令
"test": "vue-cli-service build --mode test"
添加.env.test文件
在項(xiàng)目根路徑創(chuàng)建.env.test文件,內(nèi)容為
NODE_ENV="production" //表明這是生產(chǎn)環(huán)境(需要打包) VUE_APP_CURRENTMODE="test" // 表明生產(chǎn)環(huán)境模式信息 VUE_APP_BASEURL="http://***.****.com:8000" // 測(cè)試服務(wù)器地址
修改項(xiàng)目中的api接口文件
在我的項(xiàng)目中,一般會(huì)創(chuàng)建一個(gè)api.js 來(lái)管理所有的接口url
因?yàn)槲覀冊(cè)诒镜亻_(kāi)發(fā)環(huán)境中是通過(guò)代理來(lái)連接服務(wù)器的,所以將url寫(xiě)成這
`${baseUrl}/apis/v1/login`,
在文件開(kāi)頭通過(guò)環(huán)境變量改變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 = "" }
當(dāng)需要為測(cè)試環(huán)境進(jìn)行打包的時(shí)候 , 我們只需要運(yùn)行下面指令進(jìn)行打包
npm run test
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/101701.html
摘要:實(shí)現(xiàn)輸入一行命令,執(zhí)行兩條指令,分別打包線上生產(chǎn)環(huán)境和線上測(cè)試環(huán)境的代碼。這樣配置好之后,只要執(zhí)行,它會(huì)自動(dòng)先執(zhí)行正式環(huán)境構(gòu)建打包,完成之后再自動(dòng)執(zhí)行測(cè)試環(huán)境的構(gòu)建打包,是方便接著再配置自動(dòng)壓縮,這里就需要使用到一個(gè)的插件。 需求 首先介紹一下本項(xiàng)目的背景,是基于 vue-cli3.1.1 的單頁(yè)應(yīng)用,目前測(cè)試環(huán)境和生產(chǎn)環(huán)境都在線上,并且都在同一個(gè)域名下,其中生產(chǎn)環(huán)境部署在根目錄下,測(cè)...
摘要:簡(jiǎn)介最近用框架寫(xiě)安卓版,本來(lái)打算用打包成文件即可,但發(fā)現(xiàn)配置起來(lái)復(fù)雜,還不如自己搭建環(huán)境,用工具提供的命令在終端實(shí)現(xiàn),下面介紹遇到的問(wèn)題及解決。 簡(jiǎn)介:最近用vue-cli框架寫(xiě)安卓版APP,本來(lái)打算用Hbuilder打包成.apk文件即可,但發(fā)現(xiàn)配置起來(lái)復(fù)雜,還不如自己搭建環(huán)境,用cordova工具提供的命令在終端實(shí)現(xiàn),下面介紹遇到的問(wèn)題及解決。一、打包過(guò)程首先要有node環(huán)境,然后...
摘要:簡(jiǎn)介最近用框架寫(xiě)安卓版,本來(lái)打算用打包成文件即可,但發(fā)現(xiàn)配置起來(lái)復(fù)雜,還不如自己搭建環(huán)境,用工具提供的命令在終端實(shí)現(xiàn),下面介紹遇到的問(wèn)題及解決。 簡(jiǎn)介:最近用vue-cli框架寫(xiě)安卓版APP,本來(lái)打算用Hbuilder打包成.apk文件即可,但發(fā)現(xiàn)配置起來(lái)復(fù)雜,還不如自己搭建環(huán)境,用cordova工具提供的命令在終端實(shí)現(xiàn),下面介紹遇到的問(wèn)題及解決。一、打包過(guò)程首先要有node環(huán)境,然后...
摘要:中可以使用注入變量訪問(wèn)環(huán)境變量中的配置信息向全局樣式傳入共享的全局變量在中引用添加兼容在中添加配置完整配置持續(xù)更新中揭秘系列 目錄 √ 配置多環(huán)境變量 √ 配置基礎(chǔ) vue.config.js √ 配置 proxy 跨域 √ 修復(fù) HMR(熱更新)失效 √ 修復(fù) Lazy loading routes Error: Cyclic dependency √ 添加別名alias √ 壓縮...
閱讀 3191·2019-08-30 15:55
閱讀 2952·2019-08-30 13:46
閱讀 1455·2019-08-29 17:29
閱讀 3524·2019-08-29 11:08
閱讀 3448·2019-08-29 11:04
閱讀 1096·2019-08-28 18:20
閱讀 552·2019-08-26 13:37
閱讀 1340·2019-08-26 11:49