Vue中request.js封裝及調(diào)用示例詳解
更新時間:2023年09月05日 16:07:28 作者:ClearBoth
這篇文章主要為大家介紹了Vue中request.js封裝及調(diào)用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
request.js封裝
import axios, { AxiosRequestConfig } from "axios";
import qs from "qs";
// 創(chuàng)建axios實例
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=",
// },
});
// 請求攔截器
instance.interceptors.request.use(
(config) => {
// 請求頭和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 = "請求錯誤(400)";
break;
case 401:
error.message = "未授權(quán),請登錄(401)";
break;
case 403:
error.message = "拒絕訪問(403)";
break;
case 404:
error.message = `請求地址出錯: ${error.response.config.url}`;
break;
case 405:
error.message = "請求方法未允許(405)";
break;
case 408:
error.message = "請求超時(408)";
break;
case 500:
error.message = "服務(wù)器內(nèi)部錯誤(500)";
break;
case 501:
error.message = "服務(wù)未實現(xiàn)(501)";
break;
case 502:
error.message = "網(wǎng)絡(luò)錯誤(502)";
break;
case 503:
error.message = "服務(wù)不可用(503)";
break;
case 504:
error.message = "網(wǎng)絡(luò)超時(504)";
break;
case 505:
error.message = "HTTP版本不受支持(505)";
break;
default:
error.message = `連接錯誤: ${error.message}`;
}
} else {
if (error.message == "Network Error")
error.message == "網(wǎng)絡(luò)異常,請檢查后重試!";
error.message = "連接到服務(wù)器失敗,請聯(lián)系管理員";
}
return Promise.reject(error);
}
);
//get請求
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請求
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請求
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請求
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封裝的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
webpack4+express+mongodb+vue實現(xiàn)增刪改查的示例
這篇文章主要介紹了webpack4+express+mongodb+vue 實現(xiàn)增刪改查的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
el-table點擊某一行高亮并顯示小圓點的實現(xiàn)代碼
這篇文章主要介紹了el-table點擊某一行高亮并顯示小圓點,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08
vue中使用iview自定義驗證關(guān)鍵詞輸入框問題及解決方法
這篇文章主要介紹了vue中使用iview自定義驗證關(guān)鍵詞輸入框問題及解決方法,本文通過實例結(jié)合代碼的形式給大家介紹解決方法,需要的朋友可以參考下2018-03-03
vue實現(xiàn)頁面內(nèi)容禁止選中功能,僅輸入框和文本域可選
今天小編就為大家分享一篇vue實現(xiàn)頁面內(nèi)容禁止選中功能,僅輸入框和文本域可選,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11
在vue項目中使用codemirror插件實現(xiàn)代碼編輯器功能
這篇文章主要介紹了在vue項目中使用codemirror插件實現(xiàn)代碼編輯器功能(代碼高亮顯示及自動提示),本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-08-08

