Vue中request.js封裝及調(diào)用示例詳解
request.js封裝
import axios, { AxiosRequestConfig } from "axios";
import qs from "qs";
// 創(chuàng)建axios實(shí)例
const instance = axios.create({
baseURL: process.env.VUE_APP_BASEURL,
timeout: 6000,
// headers: {
// "Content-Type": "application/x-www-form-urlencoded;charset=UTF-8",
// token:
// "MTY1Mjk1Mjg4OC42ODM2Nzg0JjJkNzUyOWQwOWU3NTU2OTE0OTU4NzI3ODUxNzkwYTNjZGMwZmRjNjAzNGQ4MGE1YzFkODE1NGVmYzk4MmMyYjM=",
// },
});
// 請(qǐng)求攔截器
instance.interceptors.request.use(
(config) => {
// 請(qǐng)求頭和token判斷等
return config;
},
(err) => {
return Promise.reject(err);
}
);
//響應(yīng)攔截器
instance.interceptors.response.use(
(res) => {
return res.data;
},
(error) => {
if (error && error.response) {
switch (error.response.status) {
case 400:
error.message = "請(qǐng)求錯(cuò)誤(400)";
break;
case 401:
error.message = "未授權(quán),請(qǐng)登錄(401)";
break;
case 403:
error.message = "拒絕訪問(403)";
break;
case 404:
error.message = `請(qǐng)求地址出錯(cuò): ${error.response.config.url}`;
break;
case 405:
error.message = "請(qǐng)求方法未允許(405)";
break;
case 408:
error.message = "請(qǐng)求超時(shí)(408)";
break;
case 500:
error.message = "服務(wù)器內(nèi)部錯(cuò)誤(500)";
break;
case 501:
error.message = "服務(wù)未實(shí)現(xiàn)(501)";
break;
case 502:
error.message = "網(wǎng)絡(luò)錯(cuò)誤(502)";
break;
case 503:
error.message = "服務(wù)不可用(503)";
break;
case 504:
error.message = "網(wǎng)絡(luò)超時(shí)(504)";
break;
case 505:
error.message = "HTTP版本不受支持(505)";
break;
default:
error.message = `連接錯(cuò)誤: ${error.message}`;
}
} else {
if (error.message == "Network Error")
error.message == "網(wǎng)絡(luò)異常,請(qǐng)檢查后重試!";
error.message = "連接到服務(wù)器失敗,請(qǐng)聯(lián)系管理員";
}
return Promise.reject(error);
}
);
//get請(qǐng)求
export function get(url: string, params = {}) {
return new Promise((resolve, reject) => {
instance
.get(url, {
params: params,
})
.then((response) => {
resolve(response);
})
.catch((err) => {
reject(err);
});
});
}
//post請(qǐng)求
export function post(url: string, params = {}) {
return new Promise((resolve, reject) => {
instance
.post(url, qs.stringify(params))
.then((response) => {
resolve(response);
})
.catch((err) => {
reject(err);
});
});
}
// delete請(qǐng)求
export function deleteFn(url: string, params: AxiosRequestConfig<any> | undefined) {
return new Promise((resolve, reject) => {
instance
.delete(url, params)
.then((response) => {
resolve(response);
})
.catch((err) => {
reject(err);
});
});
}
// put請(qǐng)求
export function put(url: string, params: any) {
return new Promise((resolve, reject) => {
instance
.put(url, qs.stringify(params))
.then((response) => {
resolve(response);
})
.catch((err) => {
reject(err);
});
});
}
export default instance;調(diào)用
import { get, post, deleteFn, put } from "../utils/request";
export const login_api = (params: {} | undefined) => {
return get("/XXXX/xxx", params);
};在.vue中使用之前先import進(jìn)來就可以了
以上就是Vue中request.js封裝及調(diào)用示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Vue request.js封裝的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue結(jié)合路由配置遞歸實(shí)現(xiàn)菜單欄功能
這篇文章主要介紹了Vue結(jié)合路由配置遞歸實(shí)現(xiàn)菜單欄,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)火鍋工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
webpack4+express+mongodb+vue實(shí)現(xiàn)增刪改查的示例
這篇文章主要介紹了webpack4+express+mongodb+vue 實(shí)現(xiàn)增刪改查的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11
el-table點(diǎn)擊某一行高亮并顯示小圓點(diǎn)的實(shí)現(xiàn)代碼
這篇文章主要介紹了el-table點(diǎn)擊某一行高亮并顯示小圓點(diǎn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08
vue中使用iview自定義驗(yàn)證關(guān)鍵詞輸入框問題及解決方法
這篇文章主要介紹了vue中使用iview自定義驗(yàn)證關(guān)鍵詞輸入框問題及解決方法,本文通過實(shí)例結(jié)合代碼的形式給大家介紹解決方法,需要的朋友可以參考下2018-03-03
vue實(shí)現(xiàn)頁面內(nèi)容禁止選中功能,僅輸入框和文本域可選
今天小編就為大家分享一篇vue實(shí)現(xiàn)頁面內(nèi)容禁止選中功能,僅輸入框和文本域可選,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-11-11
在vue項(xiàng)目中使用codemirror插件實(shí)現(xiàn)代碼編輯器功能
這篇文章主要介紹了在vue項(xiàng)目中使用codemirror插件實(shí)現(xiàn)代碼編輯器功能(代碼高亮顯示及自動(dòng)提示),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08

