今天就跟大家聊聊有關(guān)怎么在vue-cli3中實現(xiàn)分環(huán)境打包,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
第一步 : 了解環(huán)境變量概念
我們可以根目錄中的下列文件來指定環(huán)境變量:
.env # 在所有的環(huán)境中被載入 .env.local # 在所有的環(huán)境中被載入,但會被 git 忽略 .env.[mode] # 只在指定的模式中被載入 .env.[mode].local # 只在指定的模式中被載入,但會被 git 忽略
環(huán)境變量文件只包含環(huán)境變量的“鍵=值”對:
FOO=bar VUE_APP_SECRET=secret // 只有VUE_APP_開頭的環(huán)境變量可以在項目代碼中直接使用
除了 自定義的VUE_APP_* 變量之外,在你的應(yīng)用代碼中始終可用的還有兩個特殊的變量:
NODE_ENV - 會是 "development"、"production" 或 "test"中的一個。具體的值取決于應(yīng)用運行的模式。
BASE_URL - 會和 vue.config.js 中的 publicPath 選項相符,即你的應(yīng)用會部署到的基礎(chǔ)路徑。
為一個特定模式準備的環(huán)境文件的 (例如 .env.production) 將會比一般的環(huán)境文件 (例如 .env) 擁有更高的優(yōu)先級。
模式概念:
模式是 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,一個模式可以包含多個環(huán)境變量。也就是說,每個模式都將 NODE_ENV的值設(shè)置為模式的名稱(可重新賦值更改)——比如在 development 模式下 NODE_ENV 的值會被設(shè)置為 "development"。
你可以通過為 .env 文件增加后綴來設(shè)置某個模式下特有的環(huán)境變量。比如,如果你在項目根目錄創(chuàng)建一個名為 .env.development 的文件,那么在這個文件里聲明過的變量就只會在 development 模式下被載入。
你可以通過傳遞 --mode 選項參數(shù)為命令行覆寫默認的模式。例如,如果你想要在構(gòu)建命令中使用開發(fā)環(huán)境變量,請在你的 package.json 腳本中加入:
"dev-build": "vue-cli-service build --mode development",
環(huán)境變量的使用 :
只有以 VUE_APP_ 開頭的變量會被 webpack.DefinePlugin 靜態(tài)嵌入到客戶端側(cè)的包中(即在項目代碼中使用)。你可以在應(yīng)用的代碼中這樣訪問它們:
console.log(process.env.VUE_APP_SECRET)
理解指令 , 模式 , 環(huán)境變量之間的關(guān)系
我們在項目中的package.json經(jīng)常能看見以下這樣的指令
在一個 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 在服務(wù)器啟動時打開瀏覽器
--copy 在服務(wù)器啟動時將 URL 復(fù)制到剪切版
--mode 指定環(huán)境模式 (默認值: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 指定環(huán)境模式 (默認值:production)
--dest 指定輸出目錄 (默認值:dist)
--modern 面向現(xiàn)代瀏覽器帶自動回退地構(gòu)建應(yīng)用
--target app | lib | wc | wc-async (默認值:app)
--name 庫或 Web Components 模式下的名字 (默認值:package.json 中的 "name" 字段或入口文件名)
--no-clean 在構(gòu)建項目之前不清除目標目錄
--report 生成 report.html 以幫助分析包內(nèi)容
--report-json 生成 report.json 以幫助分析包內(nèi)容
--watch 監(jiān)聽文件變化
以上是兩個常用的cli指令 , 他們默認對應(yīng)的分別是development和production模式 , 如果還想了解其他指令 , 可以訪問: https://cli.vuejs.org/zh/guide/cli-service.html#cli-%E6%9C%8D%E5%8A%A1 CLI 服務(wù)
那么接下來 , 我們就開始創(chuàng)建一個用于打包測試環(huán)境的模式;
修改package.json
添加一行命令
"test": "vue-cli-service build --mode test"
添加.env.test文件
在項目根路徑創(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' // 測試服務(wù)器地址
修改項目中的api接口文件
在我的項目中,一般會創(chuàng)建一個api.js 來管理所有的接口url
因為我們在本地開發(fā)環(huán)境中是通過代理來連接服務(wù)器的,所以將url寫成這
`${baseUrl}/apis/v1/login`,
在文件開頭通過環(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 = "" }
當需要為測試環(huán)境進行打包的時候 , 我們只需要運行下面指令進行打包
npm run test
看完上述內(nèi)容,你們對怎么在vue-cli3中實現(xiàn)分環(huán)境打包有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道,感謝大家的支持。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
文章題目:怎么在vue-cli3中實現(xiàn)分環(huán)境打包-創(chuàng)新互聯(lián)
文章起源:http://www.chinadenli.net/article6/degcig.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、網(wǎng)站內(nèi)鏈、用戶體驗、定制開發(fā)、網(wǎng)站排名、全網(wǎng)營銷推廣
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)