Vue3?Axios攔截器封裝成request文件的示例詳解
可以將Axios攔截器封裝成一個(gè)單獨(dú)的request文件,以便在整個(gè)應(yīng)用程序中重復(fù)使用。
以下是一個(gè)示例,展示如何將Axios攔截器封裝成一個(gè)request文件:
1、創(chuàng)建一個(gè)名為request.js的新文件,并導(dǎo)入Axios:
import axios from 'axios';
2、創(chuàng)建一個(gè)名為request的函數(shù),并將其導(dǎo)出:
這將創(chuàng)建一個(gè)名為request的函數(shù),并將其設(shè)置為具有基本URL的新的Axios實(shí)例。要在封裝的Axios實(shí)例中添加超時(shí)設(shè)置,可以在創(chuàng)建Axios實(shí)例時(shí)傳遞timeout選項(xiàng)。
export const request = axios.create({
baseURL: 'https://example.com/api',
timeout: 5000, // 超時(shí)設(shè)置為5秒
});3、在request函數(shù)中添加攔截器:
request.interceptors.request.use(function (config) {
// 在發(fā)送請(qǐng)求之前做些什么
return config;
}, function (error) {
// 對(duì)請(qǐng)求錯(cuò)誤做些什么
return Promise.reject(error);
});
request.interceptors.response.use(function (response) {
// 對(duì)響應(yīng)數(shù)據(jù)做點(diǎn)什么
return response;
}, function (error) {
// 對(duì)響應(yīng)錯(cuò)誤做點(diǎn)什么
return Promise.reject(error);
});這將添加一個(gè)請(qǐng)求攔截器和一個(gè)響應(yīng)攔截器??梢栽谶@些攔截器中執(zhí)行需要的操作,例如在請(qǐng)求發(fā)送之前添加身份驗(yàn)證標(biāo)頭或在響應(yīng)返回后檢查響應(yīng)數(shù)據(jù)是否有誤。
4、最后,導(dǎo)出request函數(shù):
export default request;
5、現(xiàn)在可以在應(yīng)用程序中使用request函數(shù)來執(zhí)行網(wǎng)絡(luò)請(qǐng)求,并且每個(gè)請(qǐng)求都將經(jīng)過預(yù)定義的攔截器。例如:
import request from './request';
request.get('/users')
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
});這將使用封裝的Axios實(shí)例發(fā)出GET請(qǐng)求,然后使用預(yù)定義的攔截器處理響應(yīng)
完整示例:
要在發(fā)送請(qǐng)求之前攜帶Token和Username,可以使用請(qǐng)求攔截器來為所有請(qǐng)求添加身份驗(yàn)證標(biāo)頭,
請(qǐng)求攔截器檢查localStorage中是否存在名為“token”和“username”的值,并將其添加為Authorization和Username標(biāo)頭。根據(jù)實(shí)際情況調(diào)整這些標(biāo)頭的名稱和值。
要對(duì)響應(yīng)數(shù)據(jù)進(jìn)行操作,使用響應(yīng)攔截器。在上面的示例中,響應(yīng)攔截器檢查響應(yīng)數(shù)據(jù)中的“status”屬性是否為“success”。如果不是,則將其視為錯(cuò)誤,并將其作為異常拋出。異常包含響應(yīng)對(duì)象,其中包含所有響應(yīng)信息,例如響應(yīng)頭、狀態(tài)碼和響應(yīng)體。可以根據(jù)實(shí)際情況調(diào)整這些檢查和異常拋出的邏輯。
import axios from 'axios';
export const request = axios.create({
baseURL: 'https://example.com/api',
timeout: 5000, // 超時(shí)設(shè)置為5秒
});
request.interceptors.request.use(function (config) {
// 在發(fā)送請(qǐng)求之前添加身份驗(yàn)證標(biāo)頭
config.headers.Authorization = `Bearer ${localStorage.getItem('token')}`;
config.headers.Username = localStorage.getItem('username');
return config;
}, function (error) {
// 對(duì)請(qǐng)求錯(cuò)誤做些什么
return Promise.reject(error);
});
request.interceptors.response.use(function (response) {
// 對(duì)響應(yīng)數(shù)據(jù)做些什么
const responseData = response.data;
if (responseData.status !== 'success') {
const error = new Error(responseData.message || '請(qǐng)求失敗');
error.response = response;
throw error;
}
return responseData.data;
}, function (error) {
// 對(duì)響應(yīng)錯(cuò)誤做些什么
return Promise.reject(error);
});到此這篇關(guān)于Vue3 Axios攔截器封裝成request文件的文章就介紹到這了,更多相關(guān)Vue3 Axios攔截器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue前端數(shù)值轉(zhuǎn)換為千分位格式并保留兩位小數(shù)代碼示例
在Vue.js開發(fā)中我們經(jīng)常會(huì)遇到需要將數(shù)字格式化為保留兩位小數(shù)的情況,下面這篇文章主要給大家介紹了關(guān)于Vue前端數(shù)值轉(zhuǎn)換為千分位格式并保留兩位小數(shù)的相關(guān)資料,需要的朋友可以參考下2024-06-06
VUE微信H5生成二維碼海報(bào)保存在本地相冊(cè)的實(shí)現(xiàn)
本文主要介紹了VUE微信H5生成二維碼海報(bào)保存在本地相冊(cè)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
vue中調(diào)用百度地圖獲取經(jīng)緯度的實(shí)現(xiàn)
最近做個(gè)項(xiàng)目,需要實(shí)現(xiàn)獲取當(dāng)前位置的經(jīng)緯度,所以本文主要介紹了vue中調(diào)用百度地圖獲取經(jīng)緯度的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
antd upload上傳組件如何獲取服務(wù)端返回?cái)?shù)據(jù)
這篇文章主要介紹了antd upload上傳組件如何獲取服務(wù)端返回?cái)?shù)據(jù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
結(jié)合el-upload組件實(shí)現(xiàn)大文件分片上傳功能
Element UI的el-upload上傳組件相信各位小伙伴都已經(jīng)非常熟悉,最近接了一個(gè)新需求,要求在el-upload組件基礎(chǔ)上實(shí)現(xiàn)分片上傳功能,即小于等于5M文件正常上傳,大于5M文件切成5M每片上傳,那么這個(gè)功能怎么實(shí)現(xiàn)呢?一起看看吧2022-09-09

