Vue3?Axios攔截器封裝成request文件的示例詳解
可以將Axios攔截器封裝成一個單獨(dú)的request文件,以便在整個應(yīng)用程序中重復(fù)使用。
以下是一個示例,展示如何將Axios攔截器封裝成一個request文件:
1、創(chuàng)建一個名為request.js的新文件,并導(dǎo)入Axios:
import axios from 'axios';
2、創(chuàng)建一個名為request的函數(shù),并將其導(dǎo)出:
這將創(chuàng)建一個名為request的函數(shù),并將其設(shè)置為具有基本URL的新的Axios實(shí)例。要在封裝的Axios實(shí)例中添加超時設(shè)置,可以在創(chuàng)建Axios實(shí)例時傳遞timeout選項(xiàng)。
export const request = axios.create({ baseURL: 'https://example.com/api', timeout: 5000, // 超時設(shè)置為5秒 });
3、在request函數(shù)中添加攔截器:
request.interceptors.request.use(function (config) { // 在發(fā)送請求之前做些什么 return config; }, function (error) { // 對請求錯誤做些什么 return Promise.reject(error); }); request.interceptors.response.use(function (response) { // 對響應(yīng)數(shù)據(jù)做點(diǎn)什么 return response; }, function (error) { // 對響應(yīng)錯誤做點(diǎn)什么 return Promise.reject(error); });
這將添加一個請求攔截器和一個響應(yīng)攔截器??梢栽谶@些攔截器中執(zhí)行需要的操作,例如在請求發(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ò)請求,并且每個請求都將經(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請求,然后使用預(yù)定義的攔截器處理響應(yīng)
完整示例:
要在發(fā)送請求之前攜帶Token和Username,可以使用請求攔截器來為所有請求添加身份驗(yàn)證標(biāo)頭,
請求攔截器檢查localStorage中是否存在名為“token”和“username”的值,并將其添加為Authorization和Username標(biāo)頭。根據(jù)實(shí)際情況調(diào)整這些標(biāo)頭的名稱和值。
要對響應(yīng)數(shù)據(jù)進(jìn)行操作,使用響應(yīng)攔截器。在上面的示例中,響應(yīng)攔截器檢查響應(yīng)數(shù)據(jù)中的“status”屬性是否為“success”。如果不是,則將其視為錯誤,并將其作為異常拋出。異常包含響應(yīng)對象,其中包含所有響應(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è)置為5秒 }); request.interceptors.request.use(function (config) { // 在發(fā)送請求之前添加身份驗(yàn)證標(biāo)頭 config.headers.Authorization = `Bearer ${localStorage.getItem('token')}`; config.headers.Username = localStorage.getItem('username'); return config; }, function (error) { // 對請求錯誤做些什么 return Promise.reject(error); }); request.interceptors.response.use(function (response) { // 對響應(yīng)數(shù)據(jù)做些什么 const responseData = response.data; if (responseData.status !== 'success') { const error = new Error(responseData.message || '請求失敗'); error.response = response; throw error; } return responseData.data; }, function (error) { // 對響應(yīng)錯誤做些什么 return Promise.reject(error); });
到此這篇關(guān)于Vue3 Axios攔截器封裝成request文件的文章就介紹到這了,更多相關(guān)Vue3 Axios攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue3非遞歸渲染Tree組件的初步實(shí)現(xiàn)代碼
這篇文章主要介紹了Vue3非遞歸渲染Tree組件的初步實(shí)現(xiàn),文中通過代碼示例講解的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定幫助,需要的朋友可以參考下2024-05-05vue獲取DOM元素并設(shè)置屬性的兩種實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄獀ue獲取DOM元素并設(shè)置屬性的兩種實(shí)現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09Vue 通過公共字段,拼接兩個對象數(shù)組的實(shí)例
今天小編就為大家分享一篇Vue 通過公共字段,拼接兩個對象數(shù)組的實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11