摘要:前端項目上線的時候不可避免的會考慮到不同的運行環境需要前端請求不同服務地址的問題方案一一般的情況下可以使用環境變量進行分環境打包開發環境繼續使用代理需要編譯的環境通過設置環境變量去控制打包過程最終生成適用于不同環境的前端資源有關環境
前端項目上線的時候 , 不可避免的會考慮到不同的運行環境需要前端請求不同服務地址的問題
方案一 :
一般的情況下 , 可以使用vue-cli-service環境變量進行分環境打包 ;
開發環境 , 繼續使用proxy代理 ;
需要編譯的環境 , 通過設置環境變量去控制打包過程 , 最終生成適用于不同環境的前端資源 ;
有關vue-cli-service環境變量的具體解釋在另一篇文章中有詳解 , 這里我們只關注實現
首先 , 我們需要添加各個環境的env配置文件 , 放在項目的根目錄下
我們以聯調環境為例 , 添加了一個.env.build_dev 文件
.env.build_dev
NODE_ENV="production" //表明這是需要編譯的環境(需要打包) VUE_APP_CURRENTMODE="production" // 自定義的模式信息 VUE_APP_BASE_SERVER="http://****:8080" // 自定義的接口地址
在接口管理api.js文件中
import { fetchpost, fetchget, fetchput, fetchdelete } from "./config"; // 分環境打包 let baseUrl = ""; if (process.env.NODE_ENV == "development") { baseUrl = "/base" } else if (process.env.NODE_ENV == "production") { baseUrl = process.env.VUE_APP_BASE_SERVER } else { baseUrl = "" } export default { // 登錄 login(params) { return fetchpost( `${baseUrl}/apis/v1/login`, params ); }, // 修改密碼 setpsw(params) { return fetchput( `${baseUrl}/apis/v1/users/password`, params ); }, ...........略
接下來 , 我們需要在項目的package.json文件中為聯調環境添加一個編譯指令 "build_dev" , 并指定編譯模式
package.json
"scripts": { "serve": "vue-cli-service serve", "build": "vue-cli-service build", "build_dev": "vue-cli-service build --mode build_dev", "build_pre_release": "vue-cli-service build --mode build_pre_release", "build_test": "vue-cli-service build --mode build_test", "lint": "vue-cli-service lint" },
這樣 , 我們通過不同的指令去編譯對應環境的前端資源
方案二 :
另一種方式, 是將前端請求的服務地址抽離出來 , 放進配置文件里面 ,
開發環境 , 繼續使用proxy代理 ;
需要編譯的環境 , 可以直接修改編譯后的文件中的配置文件
這樣的好處如下:
1: 前端不需要重復進行打包編譯 ;
2: 自動化部署的時候可以使用腳本去替換前端資源中的配置文件 ;
3: 如果采用前端Docker化 , 可以在制作鏡像的過程中修改/替換配置文件 ;
首先 , 我們將config.json文件放置在public文件夾中(防止被webpack編譯)
在里面我們簡單存放一個服務地址字段
config.json
{ "SERVER_URL": "" }
接下來,需要保證項目開始加載前 , 我們已經獲取到這個配置文件了 , 所以在main.js 里面 , 我們需要先獲取這個配置文件 , 再實例化vue
mian.js
import axios from "axios" // vue實例 function createdVue () { return new Vue({ router, store, render: h => h(App) }).$mount("#app"); } if (process.env.NODE_ENV == "development") { // 放在public文件夾下的靜態文件需要通過絕對路徑去獲取 axios.get("/config.json").then(res=>{ // 開發環境通過proxy代理的形式 , 不需要獲取配置地址 Vue.prototype.SERVER_URL = "" createdVue() }) } else if (process.env.NODE_ENV == "production") { // 放在public文件夾下的靜態文件需要通過絕對路徑去獲取 axios.get("/config.json").then(res=>{ // 將獲取到的配置文件作為全局變量保存 Vue.prototype.SERVER_URL = res.SERVER_URL // 成功獲取到配置后再去創建vue實例 createdVue() }) }
一般項目中 , 我們都會對axios進行統一封裝 , 為axios創建一個config.js 文件 , 里面對axios請求頭 , baseUrl , 請求攔截 , 各種請求方式進行配置
在這里我們為每個請求添加baseUrl
config.js
import axios from "axios" import Vue from "vue"; import qs from "qs" import Router from "@/router.js" import {Message} from "element-ui" // axios.defaults.timeout = 10000 // 響應時間 // 獲取全局變量中的服務地址 function getBaseUrl () { return Vue.prototype.SERVER_URL } // 配置請求頭 axios.defaults.headers.post["Content-Type"] = "application/json" // 添加請求攔截器 axios.interceptors.request.use((config) => { // 為每次請求添加baseUrl config.baseURL = getBaseUrl() if (sessionStorage.token) { config.headers["Authorization"] = sessionStorage.token } return config }, (error) => { return Promise.reject(error) }) // 添加響應攔截器 axios.interceptors.response.use((res) => { // 如果錯誤碼!==0;拋出異常 if (res.data.code && res.data.code !== 0) { switch (res.data.code) { case 1001: // 無權限 Router.replace("/login") break; case 1003: // 訪問身份不合法 Router.replace("/login") break; default: break; } let message = res.data.msg || "出錯了" return Promise.reject({message: message, err: res}) } else { return Promise.resolve(res.data) } }, (error) => { let message = "服務器錯誤" return Promise.reject({message: message, err: error}) }) // 返回一個Promise(發送post請求) export function fetchpost (url, params) { return new Promise((resolve, reject) => { axios.post(url, params).then(response => { resolve(response.data) }).catch((error) => { reject(error) }) }) } // 返回一個Promise(發送get請求) export function fetchget (url, params) { return new Promise((resolve, reject) => { axios.get(url, {params: params}).then(response => { resolve(response.data) }).catch((error) => { reject(error) }) }) } // 返回一個Promise(發送put請求) export function fetchput (url, params) { return new Promise((resolve, reject) => { axios.put(url, params).then(response => { resolve(response.data) }).catch((error) => { reject(error) }) }) } // 返回一個Promise(發送delete請求) export function fetchdelete (url, params) { return new Promise((resolve, reject) => { axios.delete(url, params).then(response => { resolve(response.data) }).catch((error) => { reject(error) }) }) }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/104887.html
摘要:描述基于適配方案封裝,構建手機端模板腳手架幫你做好的配置有多環境開發封裝適配方案生產環境優化首屏加速低版本瀏覽器兼容環境發布腳本可以上手直接寫代碼多環境開發之前寫過一個多環境的方案,是基于的多環境配置方案傳送門最近新的項目采用了開始了 描述 基于vue-cli3.0+webpack 4+vant ui + sass+ rem適配方案+axios封裝,構建手機端模板腳手架 幫你做好的配置...
摘要:前言一般服務器分為本地環境,測試環境,正式環境如果每次都要修改配置就很麻煩,總結一下我使用的方法修改執行命令修改文件的,在打包的時候執行不同的命令,測試執行那正式執行這里用到了能跨平臺地設置及使用環境變量,使用 前言 一般服務器分為本地環境,測試環境,正式環境如果每次都要修改配置就很麻煩,總結一下我使用的方法 vue-demo/ |-build/ |-config/ |-d...
摘要:五六月份推薦集合查看最新的請點擊集前端最近很火的框架資源定時更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風荷舉。家住吳門,久作長安旅。五月漁郎相憶否。小楫輕舟,夢入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請::點擊::集web前端最近很火的vue2框架資源;定時更新,歡迎 Star 一下。 蘇...
摘要:五六月份推薦集合查看最新的請點擊集前端最近很火的框架資源定時更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風荷舉。家住吳門,久作長安旅。五月漁郎相憶否。小楫輕舟,夢入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請::點擊::集web前端最近很火的vue2框架資源;定時更新,歡迎 Star 一下。 蘇...
閱讀 1426·2021-10-11 11:12
閱讀 3257·2021-09-30 09:46
閱讀 1639·2021-07-28 00:14
閱讀 3143·2019-08-30 13:49
閱讀 2591·2019-08-29 11:27
閱讀 3245·2019-08-26 11:52
閱讀 610·2019-08-23 18:14
閱讀 3445·2019-08-23 16:27