Vue項(xiàng)目如何根據(jù)不同運(yùn)行環(huán)境打包項(xiàng)目
場(chǎng)景
在開(kāi)發(fā)過(guò)程中,通常會(huì)遇到這樣的問(wèn)題:
在開(kāi)發(fā)環(huán)境、測(cè)試環(huán)境和生產(chǎn)環(huán)境中我們會(huì)用到不一樣的服務(wù)接口
在生產(chǎn)環(huán)境出現(xiàn)了出現(xiàn)了某個(gè)bug,但是在測(cè)試環(huán)境不存在,這時(shí)候就需要開(kāi)發(fā)環(huán)境訪問(wèn)生產(chǎn)環(huán)境的接口
多端一體的項(xiàng)目模式
這些情況都要手動(dòng)去切換接口地址,這樣會(huì)很麻煩,有時(shí)還可能出現(xiàn)操作失誤。
這時(shí)候就需要用到cross-env進(jìn)行分環(huán)境配置了,根據(jù)不同的環(huán)境,我們使用對(duì)應(yīng)的接口,這樣也就不用手動(dòng)去操作。
第一步 安裝依賴 cross-env
使用 cross-env 解決跨平臺(tái)問(wèn)題。
在終端運(yùn)行:
npm install cross-env --save-dev // 安裝 cross-env 依賴
第二步 修改 package.json 文件
在 package.json 中 scripts 屬性中 build 命令替換為:
"scripts": {
"serve": "vue-cli-service serve",
"build": "vue-cli-service build",
"build:test": "cross-env vue-cli-service build --mode test",
"build:prod": "cross-env vue-cli-service build --mode production",
},當(dāng)我們需要配置多個(gè)環(huán)境變量時(shí),未避免package.json命令過(guò)長(zhǎng),這時(shí)候就可以選擇模式配置
默認(rèn)模式
vue-cli項(xiàng)目下默認(rèn)有三種模式:
development模式:在 vue-cli-service serve 時(shí)使用。production模式:在 vue-cli-service build 和 vue-cli-service test:e2e 時(shí)使用。test模式:在 vue-cli-service test:unit 時(shí)使用。
每個(gè)模式都會(huì)將 NODE_ENV設(shè)置為模式的名稱,比如在development模式下,NODE_ENV為 ‘development’。
自定義模式
自定義模式需要通過(guò).env文件進(jìn)行配置,.env文件分為以下類型:
.env,在所有的環(huán)境中被載入.env.local,在所有的環(huán)境中被載入,但會(huì)被 git 忽略.env.[mode],只在指定的模式中被載入.env.[mode].local,只在指定的模式中被載入,但會(huì)被 git 忽略[mode]是自定義的模式名稱
例:通過(guò)在package.json腳本中增加 --mode [mode]來(lái)指定模式。
// package.json
{
"scripts": {
"build:testing": "cross-env vue-cli-service build --mode testing",
}
}第三步 創(chuàng)建不同環(huán)境的文件
在項(xiàng)目根目錄新建 .env.development文件:
// 開(kāi)發(fā)環(huán)境模式 // 環(huán)境變量 NODE_ENV=development // 以 VUE_APP_ 開(kāi)頭的變量會(huì)被 webpack.DefinePlugin 靜態(tài)嵌入到客戶端側(cè)的包中 VUE_APP_ENV = 'development'
在項(xiàng)目根目錄新建 .env.test文件:
// 測(cè)試環(huán)境模式 // 環(huán)境變量(這里的環(huán)境變量是跟打包有關(guān)的,production則會(huì)進(jìn)行壓縮代碼等,真正跟每個(gè)環(huán)境有關(guān)的變量是下面以VUE_APP開(kāi)頭的變量) NODE_ENV=test // 以 VUE_APP_ 開(kāi)頭的變量會(huì)被 webpack.DefinePlugin 靜態(tài)嵌入到客戶端側(cè)的包中 VUE_APP_ENV = 'test'
在項(xiàng)目根目錄新建 .env.production文件:
// 線上環(huán)境模式 // 環(huán)境變量 NODE_ENV=production // 以 VUE_APP_ 開(kāi)頭的變量會(huì)被 webpack.DefinePlugin 靜態(tài)嵌入到客戶端側(cè)的包中 VUE_APP_ENV = 'production'
第四步 根據(jù)配置進(jìn)行判斷使用不同的環(huán)境服務(wù)
let baseUrl = '';
let env = process.env;
if (env.VUE_APP_ENV === 'development') {
baseUrl = `http://xxx/`; // 本地服務(wù)地址
} else if(env.VUE_APP_ENV === 'production'){
baseUrl = `http://xxx/`; // 正式環(huán)境服務(wù)地址
}else if(env.VUE_APP_ENV === 'test'){
baseUrl = `http://xxx/`; // 測(cè)試環(huán)境服務(wù)地址
}
export {
baseUrl,
env
}第五步 打包項(xiàng)目
// 測(cè)試環(huán)境打包項(xiàng)目 npm run build:test // 生產(chǎn)環(huán)境打包項(xiàng)目 npm run build:prod
結(jié)果測(cè)試:

總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于element-ui的隱藏組件el-scrollbar的使用
這篇文章主要介紹了關(guān)于element-ui的隱藏組件el-scrollbar的使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-05-05
vue.js利用Object.defineProperty實(shí)現(xiàn)雙向綁定
這篇文章主要為大家詳細(xì)介紹了vue.js利用Object.defineProperty實(shí)現(xiàn)雙向綁定,幫大家解析神秘的Object.defineProperty方法2017-03-03
Vue2 Vue-cli中使用Typescript的配置詳解
Vue作為前端三大框架之一截至到目前在github上以收獲44,873顆星,足以說(shuō)明其以悄然成為主流。下面這篇文章主要給大家介紹了關(guān)于Vue2 Vue-cli中使用Typescript的配置的相關(guān)資料,需要的朋友可以參考下。2017-07-07
vue實(shí)現(xiàn)登錄時(shí)圖形驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)登錄時(shí)圖形驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03

