第一步 : 瞭解環境變量概念html
咱們能夠根目錄中的下列文件來指定環境變量:vue
.env # 在全部的環境中被載入 .env.local # 在全部的環境中被載入,但會被 git 忽略 .env.[mode] # 只在指定的模式中被載入 .env.[mode].local # 只在指定的模式中被載入,但會被 git 忽略
環境變量文件只包含環境變量的「鍵=值」對:node
FOO=bar VUE_APP_SECRET=secret // 只有VUE_APP_開頭的環境變量能夠在項目代碼中直接使用
除了 自定義的VUE_APP_* 變量以外,在你的應用代碼中始終可用的還有兩個特殊的變量:webpack
爲一個特定模式準備的環境文件的 (例如 .env.production) 將會比通常的環境文件 (例如 .env) 擁有更高的優先級。git
模式概念:
模式是 Vue CLI 項目中一個重要的概念。通常狀況下 Vue CLI 項目有三個默認模式:web
模式不等同於 NODE_ENV,一個模式能夠包含多個環境變量。也就是說,每一個模式都將 NODE_ENV的值設置爲模式的名稱(可從新賦值更改)——好比在 development 模式下 NODE_ENV 的值會被設置爲 "development"。 vue-cli
你能夠經過爲 .env 文件增長後綴來設置某個模式下特有的環境變量。好比,若是你在項目根目錄建立一個名爲 .env.development 的文件,那麼在這個文件裏聲明過的變量就只會在 development 模式下被載入。npm
你能夠經過傳遞 --mode 選項參數爲命令行覆寫默認的模式。例如,若是你想要在構建命令中使用開發環境變量,請在你的 package.json 腳本中加入:json
"dev-build": "vue-cli-service build --mode development",
環境變量的使用 :
只有以 VUE_APP_ 開頭的變量會被 webpack.DefinePlugin 靜態嵌入到客戶端側的包中(即在項目代碼中使用)。你能夠在應用的代碼中這樣訪問它們:api
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