vue如何在多個(gè)不同服務(wù)器下訪問不同地址
一、前言
通常 vue 在本地啟動(dòng)時(shí),訪問的后端地址是同事的機(jī)器或者線上一個(gè)環(huán)境(通常叫開發(fā)環(huán)境)。假如服務(wù)器有多個(gè)環(huán)境:開發(fā)、測(cè)試、培訓(xùn)、生產(chǎn)……這樣每次發(fā)版前,都要手動(dòng)在 git 倉(cāng)庫(kù)修改后端地址,就很麻煩。
所以想要實(shí)現(xiàn)一個(gè)目的:不修改代碼,通過執(zhí)行不同命令,發(fā)布不同環(huán)境
二、實(shí)現(xiàn)思路
僅針對(duì) npm run build 打包后放到服務(wù)器運(yùn)行的項(xiàng)目,對(duì)于直接把源碼放在服務(wù)器執(zhí)行 npm run dev 的項(xiàng)目,參照本文思路,修改 build / webpack.dev.conf.js 文件中,process.env 的賦值過程即可。
把不同服務(wù)的地址都配置出來,發(fā)布不同環(huán)境時(shí),執(zhí)行不同腳本,這樣來獲取相應(yīng)的地址。
三、實(shí)踐
1. 獲取axios請(qǐng)求地址
process 是 Vue 中一個(gè)全局變量,利用這一點(diǎn),我們可以從它上邊取服務(wù)器地址,賦值給 baseURL,取到后既可以封裝到 axios 中,也可以作為他用。代碼如下:
const baseURL = process.env.BASE_API; // BASE_API是我們自定義的一個(gè)屬性,名稱隨意,只要保證所有地方一致就行
至于在哪里定義 BASE_API ,下面步驟會(huì)講到。
2. 配置不同服務(wù)器的地址
2.1 在 config 文件夾下,會(huì)看到幾個(gè) xxx.env.js 的文件,dev 和 prod 默認(rèn)就有。
每一個(gè)文件,把它當(dāng)作不同的環(huán)境,如 dev 代表開發(fā),prod 代表生產(chǎn)。
如果還有其他環(huán)境,比如培訓(xùn)環(huán)境,就把 prod.env.js 復(fù)制一份(復(fù)制 prod 不是 dev),命名為 train.env.js (名字自定義)。
2.2 修改 xxx.env.js 中內(nèi)容,以生產(chǎn)環(huán)境為例,配置一個(gè) BASE_API (就是第1步所用到的),值就是服務(wù)器地址。
注意這里的值是單引號(hào)嵌套雙引號(hào),少一層嵌套是無效的
'use strict' module.exports = { NODE_ENV: '"production"', BASE_API: '"https://www.***.com"' }
2.3 還記得剛剛創(chuàng)建的 train.env.js (如果沒有新建的可跳過這一步),對(duì)于這種手動(dòng)創(chuàng)建的,要改一下 NODE_ENV,不然就和生產(chǎn)重名了。
'use strict' module.exports = { NODE_ENV: '"train"', // production改為自定義名字 BASE_API: '"https://www.***.com"' }
3. 打包時(shí)根據(jù) process.env.NODE_ENV 判斷不同環(huán)境
build 文件夾下,webpack.prod.conf.js,找到為 const env = 這段(代碼第14行),改成如下形式
const env = (function() { const NODE_ENV = process.env.NODE_ENV; if (NODE_ENV === 'testing') { return require('../config/test.env') } else if (NODE_ENV === 'train') { // 這個(gè)就是剛剛自定義的環(huán)境 return require('../config/train.env') } else { // 默認(rèn)用生產(chǎn)環(huán)境 return require('../config/prod.env') } }())
4. 清除默認(rèn) process.env.NODE_ENV
build 文件夾下,build.js 中,默認(rèn) process.env.NODE_ENV 是 production,先注釋它
'use strict' require('./check-versions')() // process.env.NODE_ENV = 'production' // 注釋掉這一段 const ora = require('ora') const rm = require('rimraf') const path = require('path') const chalk = require('chalk') const webpack = require('webpack') const config = require('../config') const webpackConfig = require('./webpack.prod.conf')
5. 設(shè)置不同的 process.env.NODE_ENV
由于上一步清除了默認(rèn)的 process.env.NODE_ENV,要在其他地方加回來
5.1 build文件夾下,新建 buildProd.js
代碼如下
'use strict' process.env.NODE_ENV = 'production' require('./build.js')
5.2 如果有其他環(huán)境,比如上面說的培訓(xùn)環(huán)境,新建 buildTrain.js (名字自定義)
代碼如下
'use strict' process.env.NODE_ENV = 'train' // 值要和 webpack.prod.conf.js 中判斷的地方對(duì)應(yīng)上 require('./build.js')
6. 配置 script 腳本
package.json 中,配置 script 腳本。
通常我們打包時(shí),執(zhí)行 npm run build,經(jīng)過以上修改后,我們就要用不同的命令,來打包不同環(huán)境
/** * 本代碼中的注釋只是為了說明,json中是不允許寫這些注釋的 */ "scripts": { "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js", "start": "npm run dev", "unit": "jest --config test/unit/jest.conf.js --coverage", "e2e": "node test/e2e/runner.js", "test": "npm run unit && npm run e2e", "lint": "eslint --ext .js,.vue src test/unit test/e2e/specs", // "build": "node build/build.js", // 這是原來默認(rèn)的,寫在這里做參照 "build": "node build/buildProd.js", // 生產(chǎn)環(huán)境,改為 buildProd.js "train": "node build/buildTrain.js" // 培訓(xùn)環(huán)境,改為 buildTrain.js },
到這里,所有的修改都完成了,在發(fā)布不同環(huán)境時(shí),這樣執(zhí)行:
生產(chǎn)環(huán)境:npm run build;培訓(xùn)環(huán)境:npm run train。其他環(huán)境舉一反三。
把不同環(huán)境的命令交給集成工程師,讓他們寫到 Jenkins 腳本中就可以了。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue.js項(xiàng)目中管理每個(gè)頁面的頭部標(biāo)簽的兩種方法
這篇文章主要介紹了Vue.js項(xiàng)目中管理每個(gè)頁面的頭部標(biāo)簽的兩種方法,需要的朋友可以參考下2018-06-06Vue實(shí)現(xiàn)仿iPhone懸浮球的示例代碼
這篇文章主要介紹了Vue實(shí)現(xiàn)仿iPhone懸浮球的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03vue+iview如何實(shí)現(xiàn)拼音、首字母、漢字模糊搜索
這篇文章主要介紹了vue+iview如何實(shí)現(xiàn)拼音、首字母、漢字模糊搜索,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04element中datepicker日期選擇器選擇周一到周日并實(shí)現(xiàn)上一周和下一周的方法
最近項(xiàng)目中需要用到日期選擇器,所以這里給大家總結(jié)下,這篇文章主要給大家介紹了關(guān)于element中datepicker日期選擇器選擇周一到周日并實(shí)現(xiàn)上一周和下一周的相關(guān)資料,需要的朋友可以參考下2023-09-09vuex + keep-alive實(shí)現(xiàn)tab標(biāo)簽頁面緩存功能
這篇文章主要介紹了vuex + keep-alive實(shí)現(xiàn)tab標(biāo)簽頁面緩存功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10ES6 Proxy實(shí)現(xiàn)Vue的變化檢測(cè)問題
Vue3.0將采用ES6 Proxy的形式重新實(shí)現(xiàn)Vue的變化檢測(cè),在官方還沒給出新方法之前,我們先實(shí)現(xiàn)一個(gè)基于Proxy的變化檢測(cè)。感興趣的朋友跟隨小編一起看看吧2019-06-06vue中實(shí)現(xiàn)在外部調(diào)用methods的方法(推薦)
下面小編就為大家分享一篇vue中實(shí)現(xiàn)在外部調(diào)用methods的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-02-02