vue打包后修改配置后端IP地址、端口等信息兩種方法
前言
用 vue-cli 構(gòu)建的項目通常是采用前后端分離的開發(fā)模式,也就是前端與后臺完全分離,此時就需要將后臺接口地址打包進項目中,但是,我們只是改個接口地址也要重新打包那就太麻煩了。怎么解決呢?方法如下,本文推薦倆種方式。
方式1:通過創(chuàng)建 js 文件進行實現(xiàn)
優(yōu)點: 簡單易懂, 方便上手
缺點: 配置文件容易被抓取【其實也不必太過于擔心】
1、在 public 文件夾下創(chuàng)建 webconfig.js 文件
window.webConfig = { "webApiBaseUrl": "http://127.0.0.1:8001", "webSystemTitle":"標題" }
2、在 index.html 頁面應(yīng)用 js 文件
3、應(yīng)用完成之后,就可以在任何地方使用 window.webConfig
4、接口地址變化后直接修改 dist 下對應(yīng)的 webconfig.js 文件即可,修改完成重新打開項目查看 ip 端口已經(jīng)改變, 無需重新打包 vue 工程
方式二: 通過創(chuàng)建 json 文件,配合使用 axios 來實現(xiàn)
1、同樣在 public 文件夾下創(chuàng)建 webconfig.json 文件
{ "webApiBaseUrl": "http://api.xxxx.com/api", "webSystemTitle":"后臺管理系統(tǒng)" }
2、在 base.js 文件中讀取【主要是放在 axios 請求處,因為是把后端接口域名提取出來了,所以當?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 => { // 請求上面描述的本地配置文件 // 當 env=prod 時請求地址為生產(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主要是解釋如何通過 axios 發(fā)起 get 請求,讀取 json 配置文件,具體寫在哪個地方,要根據(jù)自己的實際情況而定
注意:config.json 的路徑,路徑中沒有 public!
開發(fā)的過程中其實不太理解這是為什么,但從 npm run build 編譯后生成的 dist/ 才能更好的理解為什么會這樣。如下圖,打包后的 vue 工程,config.json 是在根目錄下的,沒有 public 目錄。
接口地址變化后直接修改 dist/config.json 文件即可,無需重新打包 vue 工程
以上倆種方式,均可以實現(xiàn) vue 工程打包之后修改后端接口以及其他配置的訴求,結(jié)合實際情況運用,個人推薦使用方式 1
總結(jié)
到此這篇關(guān)于vue打包后修改配置后端IP地址、端口等信息兩種方法的文章就介紹到這了,更多相關(guān)vue打包后修改配置信息內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
element-ui使用el-date-picker日期組件常見場景分析
最近一直在使用 element-ui中的日期組件,所以想對日期組件常用的做一個簡單的總結(jié),對element-ui el-date-picker日期組件使用場景分析感興趣的朋友一起看看吧2024-05-05vue-cli創(chuàng)建項目ERROR?in?Conflict:?Multiple?assets?emit?dif
最近vue/cli創(chuàng)建項目后出現(xiàn)了錯誤,下面這篇文章主要給大家介紹了關(guān)于vue-cli創(chuàng)建項目ERROR?in?Conflict:?Multiple?assets?emit?different?content?to?the?same?filename?index.html問題的解決辦法,需要的朋友可以參考下2023-02-02Vuejs 用$emit與$on來進行兄弟組件之間的數(shù)據(jù)傳輸通信
本篇文章主要介紹了Vuejs 用$emit 與 $on 來進行兄弟組件之間的數(shù)據(jù)傳輸示例,非常具有實用價值,需要的朋友可以參考下。2017-02-02