vue interceptor 使用教程實(shí)例詳解
二次封裝axios,根據(jù)參數(shù)來實(shí)現(xiàn)多個請求多次攔截
1. 新建 axiosTool.js 文件,設(shè)置請求攔截和處理的邏輯
import Vue from 'vue'
import axios from 'axios'
//取消請求
let CancelToken = axios.CancelToken
//設(shè)置默認(rèn)請求頭,如果不需要可以取消這一步
axios.defaults.headers = {
'X-Requested-With': 'XMLHttpRequest'
}
// 請求超時(shí)的時(shí)間限制
axios.defaults.timeout = 20000
// 開始設(shè)置請求 發(fā)起的攔截處理
// config 代表發(fā)起請求的參數(shù)的實(shí)體
axios.interceptors.request.use(config => {
// 得到參數(shù)中的 requestName 字段,用于決定下次發(fā)起請求,取消對應(yīng)的 相同字段的請求
// 如果沒有 requestName 就默認(rèn)添加一個 不同的時(shí)間戳
let requestName
if(config.method === 'post'){
if(config.data && config.data.requestName){
requestName = config.data.requestName
}else{
requestName = new Date().getTime()
}
}else{
if(config.params && config.params.requestName){
requestName = config.params.requestName
}else{
requestName = new Date().getTime()
}
}
// 判斷,如果這里拿到的參數(shù)中的 requestName 在上一次請求中已經(jīng)存在,就取消上一次的請求
if (requestName) {
if (axios[requestName] && axios[requestName].cancel) {
axios[requestName].cancel()
}
config.cancelToken = new CancelToken(c => {
axios[requestName] = {}
axios[requestName].cancel = c
})
}
return config
}, error => {
return Promise.reject(error)
})
// 請求到結(jié)果的攔截處理
axios.interceptors.response.use(config => {
// 返回請求正確的結(jié)果
return config
}, error => {
// 錯誤的請求結(jié)果處理,這里的代碼根據(jù)后臺的狀態(tài)碼來決定錯誤的輸出信息
if (error && error.response) {
switch (error.response.status) {
case 400:
error.message = '錯誤請求'
break
case 401:
error.message = '未授權(quán),請重新登錄'
break
case 403:
error.message = '拒絕訪問'
break
case 404:
error.message = '請求錯誤,未找到該資源'
break
case 405:
error.message = '請求方法未允許'
break
case 408:
error.message = '請求超時(shí)'
break
case 500:
error.message = '服務(wù)器端出錯'
break
case 501:
error.message = '網(wǎng)絡(luò)未實(shí)現(xiàn)'
break
case 502:
error.message = '網(wǎng)絡(luò)錯誤'
break
case 503:
error.message = '服務(wù)不可用'
break
case 504:
error.message = '網(wǎng)絡(luò)超時(shí)'
break
case 505:
error.message = 'http版本不支持該請求'
break
default:
error.message = `連接錯誤${error.response.status}`
}
} else {
error.message = "連接到服務(wù)器失敗"
}
return Promise.reject(error.message)
})
// 將axios 的 post 方法,綁定到 vue 實(shí)例上面的 $post
Vue.prototype.$post = function (url, params) {
return new Promise((resolve, reject) => {
axios.post(url, params)
.then(res => {
resolve(res)
}).catch(err => {
reject(err)
})
})
}
// 將axios 的 get 方法,綁定到 vue 實(shí)例上面的 $get
Vue.prototype.$get = function (url, params) {
return new Promise((resolve, reject) => {
axios.get(url, {
params: params
}).then(res => {
resolve(res) // 返回請求成功的數(shù)據(jù) data
}).catch(err => {
reject(err)
})
})
}
// 請求示例
// requestName 為多余的參數(shù) 作為請求的標(biāo)識,下次發(fā)起相同的請求,就會自動取消上一次還沒有結(jié)束的請求
// 比如正常的請求參數(shù)只有一個 name: '123',但是這里我們需要額外再加上一個 requestName
/**
this.$post(url, { name: '123', requestName: 'post_1' })
.then(res => {
console.log(`請求成功:${res}`)
})
*/
export default axios
2. 再 main.js 中引入該文件
import { axios } from './static/js/axiosTool'
3. 在組件中直接使用即可
this.$post(this.url2, {
name: "王",
docType: "pson",
requestName: 'name02'
}).then(res => {
console.log(res)
})
this.$get(this.url, {
name: "李",
requestName: 'name01'
}).then(res => {
console.log(res)
})
4. 效果如圖:

總結(jié)
以上所述是小編給大家介紹的vue interceptor 使用教程實(shí)例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Vue.js實(shí)現(xiàn)一個SPA登錄頁面的過程【推薦】
本篇文章主要介紹了Vue.js寫一個SPA登錄頁面過程的相關(guān)知識,具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-04-04
基于Vue2的獨(dú)立構(gòu)建與運(yùn)行時(shí)構(gòu)建的差別(詳解)
下面小編就為大家分享一篇基于Vue2的獨(dú)立構(gòu)建與運(yùn)行時(shí)構(gòu)建的差別詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12
vue3組合式API實(shí)現(xiàn)todo列表效果
這篇文章主要介紹了vue3組合式API實(shí)現(xiàn)todo列表,下面用組合式?API的寫法,實(shí)現(xiàn)一個可新增、刪除的todo列表效果,需要的朋友可以參考下2024-08-08
記錄一個Vue3簡易微信右滑刪除邏輯的思路實(shí)現(xiàn)
本文主要介紹了記錄一個Vue3簡易微信右滑邏輯的思路實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
vue項(xiàng)目中openlayers繪制行政區(qū)劃
這篇文章主要為大家詳細(xì)介紹了vue項(xiàng)目中openlayers繪制行政區(qū)劃,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12

