vue打包后修改配置后端IP地址、端口等信息兩種方法
前言
用 vue-cli 構(gòu)建的項(xiàng)目通常是采用前后端分離的開(kāi)發(fā)模式,也就是前端與后臺(tái)完全分離,此時(shí)就需要將后臺(tái)接口地址打包進(jìn)項(xiàng)目中,但是,我們只是改個(gè)接口地址也要重新打包那就太麻煩了。怎么解決呢?方法如下,本文推薦倆種方式。
方式1:通過(guò)創(chuàng)建 js 文件進(jìn)行實(shí)現(xiàn)
優(yōu)點(diǎn): 簡(jiǎn)單易懂, 方便上手
缺點(diǎn): 配置文件容易被抓取【其實(shí)也不必太過(guò)于擔(dān)心】
1、在 public 文件夾下創(chuàng)建 webconfig.js 文件
window.webConfig = { "webApiBaseUrl": "http://127.0.0.1:8001", "webSystemTitle":"標(biāo)題" }
2、在 index.html 頁(yè)面應(yīng)用 js 文件
3、應(yīng)用完成之后,就可以在任何地方使用 window.webConfig
4、接口地址變化后直接修改 dist 下對(duì)應(yīng)的 webconfig.js 文件即可,修改完成重新打開(kāi)項(xiàng)目查看 ip 端口已經(jīng)改變, 無(wú)需重新打包 vue 工程
方式二: 通過(guò)創(chuàng)建 json 文件,配合使用 axios 來(lái)實(shí)現(xiàn)
1、同樣在 public 文件夾下創(chuàng)建 webconfig.json 文件
{ "webApiBaseUrl": "http://api.xxxx.com/api", "webSystemTitle":"后臺(tái)管理系統(tǒng)" }
2、在 base.js 文件中讀取【主要是放在 axios 請(qǐng)求處,因?yàn)槭前押蠖私涌谟蛎崛〕鰜?lái)了,所以當(dāng)?shù)懒?base.js 文件】
/** * 接口域名的管理 */ import axios from 'axios' const base = { web: getWebApiBaseUrl(), signalRApiHost: process.env.VUE_APP_SignalR_APIHOST, } function getWebApiBaseUrl(){ let WebApiBaseUrl = process.env.VUE_APP_BASE_APIHOST axios.get('../webconfig.json').then(res => { // 請(qǐng)求上面描述的本地配置文件 // 當(dāng) env=prod 時(shí)請(qǐng)求地址為生產(chǎn)環(huán)境 const node_env = process.env.NODE_ENV if(node_env == 'production'){ WebApiBaseUrl = res.data.webApiBaseUrl } else { WebApiBaseUrl = process.env.VUE_APP_BASE_APIHOST } }) return WebApiBaseUrl // Vue.prototype.WebApiBaseUrl; } export default base
3、步驟2主要是解釋如何通過(guò) axios 發(fā)起 get 請(qǐng)求,讀取 json 配置文件,具體寫(xiě)在哪個(gè)地方,要根據(jù)自己的實(shí)際情況而定
注意:config.json 的路徑,路徑中沒(méi)有 public!
開(kāi)發(fā)的過(guò)程中其實(shí)不太理解這是為什么,但從 npm run build 編譯后生成的 dist/ 才能更好的理解為什么會(huì)這樣。如下圖,打包后的 vue 工程,config.json 是在根目錄下的,沒(méi)有 public 目錄。
接口地址變化后直接修改 dist/config.json 文件即可,無(wú)需重新打包 vue 工程
以上倆種方式,均可以實(shí)現(xiàn) vue 工程打包之后修改后端接口以及其他配置的訴求,結(jié)合實(shí)際情況運(yùn)用,個(gè)人推薦使用方式 1
總結(jié)
到此這篇關(guān)于vue打包后修改配置后端IP地址、端口等信息兩種方法的文章就介紹到這了,更多相關(guān)vue打包后修改配置信息內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
element-ui使用el-date-picker日期組件常見(jiàn)場(chǎng)景分析
最近一直在使用 element-ui中的日期組件,所以想對(duì)日期組件常用的做一個(gè)簡(jiǎn)單的總結(jié),對(duì)element-ui el-date-picker日期組件使用場(chǎng)景分析感興趣的朋友一起看看吧2024-05-05vue2.0實(shí)現(xiàn)前端星星評(píng)分功能組件實(shí)例代碼
本文通過(guò)實(shí)例代碼給大家介紹了vue2.0實(shí)現(xiàn)前端星星評(píng)分功能組件,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2018-02-02vue3開(kāi)啟攝像頭并進(jìn)行拍照的實(shí)現(xiàn)示例
本文主要介紹了vue3開(kāi)啟攝像頭并進(jìn)行拍照的實(shí)現(xiàn)示例,主要是使用navigator.mediaDevices.getUserMedia這個(gè)API來(lái)實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01基于vue的短信驗(yàn)證碼倒計(jì)時(shí)demo
這篇文章主要介紹了基于vue的短信驗(yàn)證碼倒計(jì)時(shí)demo,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09vue-cli創(chuàng)建項(xiàng)目ERROR?in?Conflict:?Multiple?assets?emit?dif
最近vue/cli創(chuàng)建項(xiàng)目后出現(xiàn)了錯(cuò)誤,下面這篇文章主要給大家介紹了關(guān)于vue-cli創(chuàng)建項(xiàng)目ERROR?in?Conflict:?Multiple?assets?emit?different?content?to?the?same?filename?index.html問(wèn)題的解決辦法,需要的朋友可以參考下2023-02-02手把手教你Vue3?按需引入?Echarts的過(guò)程(收藏)
新項(xiàng)目采用?Vue3?作為前端項(xiàng)目框架,避免不了要使用?echarts,但是在使用的時(shí)候,出現(xiàn)了與?Vue2?使用不一樣的地方,所以特別記下來(lái),希望給到有需要的同學(xué)一些幫助2023-10-10Vuejs 用$emit與$on來(lái)進(jìn)行兄弟組件之間的數(shù)據(jù)傳輸通信
本篇文章主要介紹了Vuejs 用$emit 與 $on 來(lái)進(jìn)行兄弟組件之間的數(shù)據(jù)傳輸示例,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。2017-02-02vue引用CSS樣式實(shí)現(xiàn)手機(jī)充電效果
這篇文章主要介紹了vue引用CSS樣式實(shí)現(xiàn)手機(jī)充電效果,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01Vue.js基礎(chǔ)學(xué)習(xí)之class與樣式綁定
這篇文章主要為大家介紹了Vue.js的Class與樣式綁定,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03