Vue使用Axios請求攔截器的案例詳解
Vue中Axios攔截器
在Vue項(xiàng)目中,Axios是一個非常流行的HTTP客戶端,用于發(fā)送請求和接收響應(yīng)。Axios攔截器是Axios的一個強(qiáng)大功能,它允許你在請求發(fā)送之前和響應(yīng)返回之后對請求和響應(yīng)進(jìn)行處理和攔截。通過攔截器,你可以添加請求頭、處理請求參數(shù)、處理錯誤等。本文將結(jié)合實(shí)際案例,詳細(xì)介紹如何在Vue中使用Axios攔截器。
一、安裝Axios
首先,你需要在Vue3項(xiàng)目中安裝Axios。你可以使用npm或yarn等包管理工具進(jìn)行安裝。
npm install axios
或者
yarn add axios
二、創(chuàng)建Axios實(shí)例
在Vue3項(xiàng)目中,通常會在項(xiàng)目的某個地方創(chuàng)建一個Axios實(shí)例,并對其進(jìn)行配置。你可以將Axios實(shí)例放在一個單獨(dú)的文件中,例如src/axios.js。
// src/axios.js
import axios from 'axios';
// 創(chuàng)建Axios實(shí)例
const axiosInstance = axios.create({
baseURL: '// 你的基礎(chǔ)URL', // 設(shè)置請求的baseURL
timeout: 5000, // 設(shè)置請求超時時間
});
// 導(dǎo)出Axios實(shí)例
export default axiosInstance;
在上面的代碼中,我們使用axios.create方法創(chuàng)建了一個Axios實(shí)例,并傳遞了一些配置選項(xiàng),例如baseURL和timeout。
三、設(shè)置請求攔截器
請求攔截器允許你在請求發(fā)送之前對請求進(jìn)行處理。你可以在Axios實(shí)例中使用interceptors.request.use方法來添加請求攔截器。
// src/axios.js
import axios from 'axios';
// 創(chuàng)建Axios實(shí)例
const axiosInstance = axios.create({
baseURL: '// 你的基礎(chǔ)URL',
timeout: 5000,
});
// 添加請求攔截器
axiosInstance.interceptors.request.use(
(config) => {
// 在發(fā)送請求之前做些什么
// 例如,添加請求頭
const token = localStorage.getItem('token');
if (token) {
config.headers['Authorization'] = `Bearer ${token}`;
}
// 處理請求參數(shù)
// config.params = {
// ...config.params,
// key: 'value',
// };
return config;
},
(error) => {
// 對請求錯誤做些什么
return Promise.reject(error);
}
);
// 導(dǎo)出Axios實(shí)例
export default axiosInstance;
在上面的代碼中,我們添加了一個請求攔截器。在攔截器中,我們檢查本地存儲中是否存在token,如果存在,則將其添加到請求頭中。你還可以對請求參數(shù)進(jìn)行處理,例如添加或修改參數(shù)。
四、設(shè)置響應(yīng)攔截器
響應(yīng)攔截器允許你在響應(yīng)返回之后對響應(yīng)進(jìn)行處理。你可以在Axios實(shí)例中使用interceptors.response.use方法來添加響應(yīng)攔截器。
// src/axios.js
import axios from 'axios';
// 創(chuàng)建Axios實(shí)例
const axiosInstance = axios.create({
baseURL: '// 你的基礎(chǔ)URL',
timeout: 5000,
});
// 添加請求攔截器(同上)
// 添加響應(yīng)攔截器
axiosInstance.interceptors.response.use(
(response) => {
// 對響應(yīng)數(shù)據(jù)做些什么
// 例如,處理響應(yīng)數(shù)據(jù)格式
// response.data = {
// ...response.data,
// key: 'value',
// };
return response;
},
(error) => {
// 對響應(yīng)錯誤做些什么
const { response } = error;
if (response) {
// 判斷錯誤狀態(tài)碼
if (response.status === 400) {
// 請求錯誤
} else if (response.status === 401) {
// 未授權(quán),請重新登錄
} else if (response.status === 403) {
// 拒絕訪問(403)
}
return Promise.reject(response.data);
} else {
console.error('網(wǎng)絡(luò)連接異常,請稍后再試!');
}
}
);
// 導(dǎo)出Axios實(shí)例
export default axiosInstance;
在上面的代碼中,我們添加了一個響應(yīng)攔截器。在攔截器中,我們可以對響應(yīng)數(shù)據(jù)進(jìn)行處理,例如修改數(shù)據(jù)格式。我們還可以根據(jù)響應(yīng)的狀態(tài)碼來處理不同的錯誤情況。
五、在Vue組件中使用Axios實(shí)例
現(xiàn)在,我們已經(jīng)在項(xiàng)目中創(chuàng)建了Axios實(shí)例,并添加了請求和響應(yīng)攔截器。接下來,我們可以在Vue組件中使用這個Axios實(shí)例來發(fā)送請求。
<!-- src/components/YourComponent.vue -->
<template>
<div>數(shù)據(jù)展示</div>
</template>
<script>
import axiosInstance from '../axios';
export default {
name: 'YourComponent',
mounted() {
axiosInstance.get('/your-endpoint')
.then(data => {
console.log(data);
})
.catch(error => {
console.error('錯誤:', error);
});
},
};
</script>
在上面的代碼中,我們在Vue組件的mounted生命周期鉤子中使用了Axios實(shí)例來發(fā)送一個GET請求。請求成功后,我們將響應(yīng)數(shù)據(jù)打印到控制臺。如果請求失敗,我們將錯誤信息打印到控制臺。
六、封裝請求方法
為了更方便地在項(xiàng)目中發(fā)送請求,我們可以將常用的請求方法封裝起來。例如,我們可以封裝GET和POST請求方法。
// src/api/axios.js
import axios from 'axios';
// 創(chuàng)建Axios實(shí)例(同上)
// 封裝GET請求方法
export function getRequest(url, params = {}) {
return axiosInstance.get(url, { params });
}
// 封裝POST請求方法
export function postRequest(url, data = {}) {
return axiosInstance.post(url, data);
}
現(xiàn)在,我們可以在Vue組件中使用封裝好的請求方法來發(fā)送請求。
<!-- src/components/YourComponent.vue -->
<template>
<div>數(shù)據(jù)展示</div>
</template>
<script>
import { getRequest, postRequest } from '../api/axios';
export default {
name: 'YourComponent',
mounted() {
// 使用GET請求方法
getRequest('/your-get-endpoint', { param1: 'value1' })
.then(data => {
console.log('GET請求響應(yīng):', data);
})
.catch(error => {
console.error('GET請求錯誤:', error);
});
// 使用POST請求方法
postRequest('/your-post-endpoint', { key: 'value' })
.then(data => {
console.log('POST請求響應(yīng):', data);
})
.catch(error => {
console.error('POST請求錯誤:', error);
});
},
};
</script>
七、統(tǒng)一管理API接口
在項(xiàng)目中,我們可能會有很多API接口。為了方便管理和維護(hù),我們可以將這些接口統(tǒng)一管理起來。例如,我們可以在src/api目錄下創(chuàng)建一個api.js文件,并在其中定義所有的API接口。
// src/api/api.js
import { getRequest, postRequest } from './axios';
// 定義用戶相關(guān)API接口
export class UserApi {
static async login(params) {
return postRequest('/login', params);
}
static async register(params) {
return postRequest('/register', params);
}
static async getUserInfo(params) {
return getRequest('/userInfo', params);
}
}
// 定義書籍相關(guān)API接口
export class BookApi {
static async getBookList(params) {
return getRequest('/bookList', params);
}
}
現(xiàn)在,我們可以在Vue組件中使用統(tǒng)一管理好的API接口來發(fā)送請求。
<!-- src/components/YourComponent.vue -->
<template>
<div>
<button @click="handleLogin">登錄</button>
</div>
</template>
<script>
import { UserApi } from '../api/api';
export default {
name: 'YourComponent',
methods: {
async handleLogin() {
const params = {
username: 'admin',
password: '123456',
};
try {
const response = await UserApi.login(params);
console.log('登錄成功:', response);
} catch (error) {
console.error('登錄失敗:', error);
}
},
},
};
</script>
拓展:Vue配置axios響應(yīng)攔截器
一個項(xiàng)目會發(fā)送很多請求到后端,每個請求都有如下的響應(yīng)

不想每個請求都去判斷里面的status,那么可以使用axios的響應(yīng)攔截器,對服務(wù)端返回的一些相同點(diǎn)做統(tǒng)一的處理
比如說如果有報錯,就統(tǒng)一彈出這么個錯誤信息

在src目錄下新建utils目錄里新建api.js(名字隨你自己)

原先彈出錯誤信息,可以直接只用
this.$message.error('請輸入正確格式')
但是現(xiàn)在是在js文件里,需要額外單獨(dú)引入


配置axios響應(yīng)攔截器(其實(shí)也可以配置請求攔截器,就是在所有請求里添加什么什么什么,比如說統(tǒng)一添加請求頭)

這里先介紹響應(yīng)攔截器
import axios from 'axios'
import { Message } from 'element-ui';
import router from '../router'//導(dǎo)入文件夾,自動會去找里面的index.js
const instances = axios.create({
baseURL: 'http://localhost',
});
//響應(yīng)攔截器
instances.interceptors.response.use(success=>{//這個success指的是調(diào)用接口成功
console.log('響應(yīng)攔截器,chenggong')
},error=>{//接口根本沒有調(diào)用到或者服務(wù)器掛了,各種原因
console.log('響應(yīng)攔截器,shibai',error)
Message.error({message:error})
});
// //可以在所有請求前添加前置路徑
// let base='';
// //封裝請求并導(dǎo)出
// export const postRequest=(url,params)=>{
// return axios({
// method:'post',
// url:'${base}${url}',
// data:params
// })
// }
export default instances;記得在main.js引入

引入的即為utils.api.js里

導(dǎo)出的
下面第一張圖用的是反引號,注意



到此這篇關(guān)于Vue使用Axios請求攔截器的案例詳解的文章就介紹到這了,更多相關(guān)Vue Axios請求攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue項(xiàng)目之webpack打包靜態(tài)資源路徑不準(zhǔn)確的問題
這篇文章主要介紹了vue項(xiàng)目之webpack打包靜態(tài)資源路徑不準(zhǔn)確的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
詳解vue-flickity的fullScreen功能實(shí)現(xiàn)
這篇文章主要介紹了詳解vue-flickity的fullScreen功能實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
Vue導(dǎo)出頁面為PDF格式的實(shí)現(xiàn)思路
這篇文章主要介紹了Vue導(dǎo)出頁面為PDF格式的實(shí)現(xiàn)思路,其實(shí)思路也很簡單,就是將頁面轉(zhuǎn)換成圖片格式.然后通過圖片的base64碼.生成PDF..感興趣的朋友跟隨腳本之家小編一起看看吧2018-07-07
Vue利用AJAX請求獲取XML文件數(shù)據(jù)的操作方法
在現(xiàn)代Web開發(fā)中,從前端框架到后端API的交互是必不可少的一部分,Vue.js作為一個輕量級且功能強(qiáng)大的前端框架,支持多種方式與服務(wù)器通信,從而獲取或發(fā)送數(shù)據(jù),本文將詳細(xì)介紹如何在Vue.js項(xiàng)目中使用AJAX請求來獲取XML格式的數(shù)據(jù),需要的朋友可以參考下2024-09-09
SpringBoot+Vue項(xiàng)目線上買菜系統(tǒng)源碼展示
本線上買菜系統(tǒng)采用的數(shù)據(jù)庫是Mysql,使用springboot框架開發(fā)。在設(shè)計過程中,充分保證了系統(tǒng)代碼的良好可讀性、實(shí)用性、易擴(kuò)展性、通用性、便于后期維護(hù)、操作方便以及頁面簡潔等特點(diǎn),需要的朋友可以參考下2022-08-08
vue3.2?reactive函數(shù)問題小結(jié)
reactive用來包裝一個對象,使其每個對象屬性都具有響應(yīng)性(也就是深層次響應(yīng)式),這篇文章主要介紹了vue3.2?reactive函數(shù)注意點(diǎn)及問題小結(jié),需要的朋友可以參考下2022-12-12
Vue ElementUi同時校驗(yàn)多個表單(巧用new promise)
這篇文章主要介紹了巧用new promise實(shí)現(xiàn)Vue ElementUi同時校驗(yàn)多個表單功能,實(shí)現(xiàn)的方法有很多種,本文給大家?guī)淼氖且环N比較完美的方案,需要的朋友可以參考下2018-06-06

