二次封裝axios,根據(jù)參數(shù)來實現(xiàn)多個請求多次攔截
成都創(chuàng)新互聯(lián)公司2013年成立,先為個舊等服務建站,個舊等地企業(yè),進行企業(yè)商務咨詢服務。為個舊企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務解決您的所有建站問題。
1. 新建 axiosTool.js 文件,設置請求攔截和處理的邏輯
import Vue from 'vue'
import axios from 'axios'
//取消請求
let CancelToken = axios.CancelToken
//設置默認請求頭,如果不需要可以取消這一步
axios.defaults.headers = {
'X-Requested-With': 'XMLHttpRequest'
}
// 請求超時的時間限制
axios.defaults.timeout = 20000
// 開始設置請求 發(fā)起的攔截處理
// config 代表發(fā)起請求的參數(shù)的實體
axios.interceptors.request.use(config => {
// 得到參數(shù)中的 requestName 字段,用于決定下次發(fā)起請求,取消對應的 相同字段的請求
// 如果沒有 requestName 就默認添加一個 不同的時間戳
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 = '請求超時'
break
case 500:
error.message = '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 使用教程實例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!
新聞名稱:vueinterceptor使用教程實例詳解
網(wǎng)站鏈接:http://www.yijiale78.com/article48/gcshep.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)、標簽優(yōu)化、外貿(mào)網(wǎng)站建設、全網(wǎng)營銷推廣、建站公司、軟件開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)