Vue3中axios請(qǐng)求封裝、請(qǐng)求攔截與相應(yīng)攔截詳解
前言
對(duì)于三者放在Service.js中封裝,方便使用
axios.create 的作用是創(chuàng)建一個(gè)新的 axios 實(shí)例,該實(shí)例可以具有自定義配置。通過使用 axios.create,您可以為任何 API 生成一個(gè)客戶端,并在使用同一客戶端的任何調(diào)用中重復(fù)使用相同的配置。這使得在應(yīng)用程序中使用多個(gè) API 時(shí)更加方便,因?yàn)槟梢詾槊總€(gè) API 創(chuàng)建一個(gè)單獨(dú)的實(shí)例,并在每個(gè)實(shí)例中設(shè)置不同的配置。
axios.create 方法接受一個(gè)配置對(duì)象作為參數(shù),該對(duì)象包含以下屬性:
- baseURL:用于所有請(qǐng)求的基本 URL。
- headers:要發(fā)送的自定義 headers。
- timeout:指定請(qǐng)求超時(shí)之前的毫秒數(shù)。
- withCredentials:指示是否應(yīng)該使用跨站點(diǎn)訪問控制(CORS)憑據(jù)。
- xsrfCookieName:用作 xsrf 令牌值的cookie的名稱。
- xsrfHeaderName:包含 xsrf 令牌值的 HTTP 頭的名稱。
例如,以下代碼創(chuàng)建了一個(gè)新的 axios 實(shí)例,并將其配置為使用 /api/ 作為基本 URL:
const instance = axios.create({
baseURL: '/api/'
});axios請(qǐng)求封裝
// 用create創(chuàng)建axios實(shí)例
const Service = axios.create({
timeout: 3000,
baseURL: 'http://127.0.0.1:8888/api/private/v1/',
headers: { 'Content-type': 'application/json;charset=utf-8' }
})
// get 數(shù)據(jù)請(qǐng)求封裝
export const get = config => {
return Service({
...config,
method: 'get',
data: config.data,
})
}
// post 數(shù)據(jù)請(qǐng)求封裝
export const post = config => {
return Service({
...config,
method: 'post',
data: config.data,
})
}請(qǐng)求攔截和響應(yīng)攔截
在 Vue3 中,可以使用 Axios 庫來進(jìn)行 HTTP 請(qǐng)求。Axios 庫提供了請(qǐng)求攔截器和響應(yīng)攔截器,以便在請(qǐng)求發(fā)送和響應(yīng)返回時(shí)執(zhí)行一些操作。
請(qǐng)求攔截器可以用于在請(qǐng)求發(fā)送前執(zhí)行一些操作,例如添加 token、設(shè)置請(qǐng)求頭等。響應(yīng)攔截器可以用于在響應(yīng)返回后執(zhí)行一些操作,例如處理錯(cuò)誤信息、剝離無效數(shù)據(jù)等。
let loadingObj = null;
// 請(qǐng)求攔截,增加loading,對(duì)請(qǐng)求統(tǒng)一處理
Service.interceptors.request.use((config) => {
loadingObj = ElLoading.service({
lock: true,
text: 'Loading',
background: 'rgba(0, 0, 0, 0.7)',
})
return config;
})
// 相應(yīng)攔截,對(duì)返回值做同意處理
Service.interceptors.response.use(response => {
loadingObj.close();
const data = response.data;
if (!data.data) {
ElMessage.error(data.meta.msg || '服務(wù)器錯(cuò)誤')
}
else {
ElMessage({
message: '登錄成功',
type: 'success',
duration: 1500
})
}
return response.data;
}, error => {
loadingObj.close();
ElMessage({
message: '服務(wù)器錯(cuò)誤',
type: 'error',
duration: 2000
})
})接口的請(qǐng)求
import { get, post } from './service'
// 登錄數(shù)據(jù)請(qǐng)求
export const loginAPI = data => {
return post({
url: '/login',
data
})
}總結(jié)
到此這篇關(guān)于Vue3中axios請(qǐng)求封裝、請(qǐng)求攔截與相應(yīng)攔截的文章就介紹到這了,更多相關(guān)Vue3 axios請(qǐng)求封裝、攔截內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue監(jiān)聽頁面變化的實(shí)現(xiàn)方法小結(jié)
在Vue.js應(yīng)用開發(fā)過程中,監(jiān)聽頁面變化是一個(gè)非常常見的需求,無論是為了響應(yīng)用戶交互、優(yōu)化性能,還是實(shí)現(xiàn)復(fù)雜的業(yè)務(wù)邏輯,監(jiān)聽頁面變化的能力都是不可或缺的,本文將詳細(xì)介紹如何在Vue項(xiàng)目中實(shí)現(xiàn)頁面變化監(jiān)聽,需要的朋友可以參考下2024-10-10
Vue中的assets和static目錄:使用場(chǎng)景及區(qū)別說明
這篇文章主要介紹了Vue中的assets和static目錄:使用場(chǎng)景及區(qū)別說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
Vue使用fabric.js實(shí)現(xiàn)局部截圖與大圖預(yù)覽功能
這篇文章主要為大家詳細(xì)介紹了Vue如何使用fabric.js實(shí)現(xiàn)局部截圖與el-image-viewer大圖預(yù)覽功能,文中的示例代碼講解詳細(xì),感興趣的可以了解下2024-02-02

