封裝一下vue中的axios示例代碼詳解
在vue項(xiàng)目中,和后臺(tái)交互獲取數(shù)據(jù)這塊,我們通常使用的是axios庫(kù),它是基于promise的http庫(kù),可運(yùn)行在瀏覽器端和node.js中。他有很多優(yōu)秀的特性,例如攔截請(qǐng)求和響應(yīng)、取消請(qǐng)求、轉(zhuǎn)換json、客戶端防御cSRF等。所以我們的尤大大也是果斷放棄了對(duì)其官方庫(kù)vue-resource的維護(hù),直接推薦我們使用axios庫(kù)。如果還對(duì)axios不了解的,可以移步axios文檔。
安裝
npm install axios; // 安裝axios
好了,下面開(kāi)始今天的正文。
此次封裝用以解決: (對(duì)于登錄功能的可以直接使用,其他網(wǎng)絡(luò)請(qǐng)求也可以直接用,如果有潔癖,可以把token有關(guān)的幾行代碼刪掉)
ps:使用時(shí)得的引入axios時(shí): import axios from '這個(gè)文件的名字及相對(duì)路徑'
- 接受后臺(tái)token
- post參數(shù)自動(dòng)轉(zhuǎn)換,省略qs.stringify()
- 后臺(tái)token過(guò)期之后自動(dòng)清除本地?cái)?shù)據(jù),以便下次再次輸入賬號(hào)密碼
- 更好的錯(cuò)誤提示信息
/**
* 封裝網(wǎng)絡(luò)請(qǐng)求
*/
import axios from "axios"
import qs from "querystring"
import store from '../store'
import router from '../router'
//token過(guò)期之后重新回登錄界面
const toLogin = () =>{
router.push("/login")
}
// 錯(cuò)誤信息響應(yīng)方法
const errroHandle = (status,other) => {
switch(status){
case 400:
console.log("服務(wù)器無(wú)法理解請(qǐng)求信息");
break;
case 401:
console.log("用戶信息驗(yàn)證失敗");
localStorage.removeItem("token"); // 可選項(xiàng)
toLogin();
break;
case 403:
console.log("請(qǐng)求被限制");
localStorage.removeItem("token"); // 可選項(xiàng)
toLogin();
break;
case 404:
console.log("客戶端請(qǐng)求信息錯(cuò)誤");
break;
default:
console.log(other);
break;
}
}
// 創(chuàng)建axios對(duì)象
const instance = axios.create({
timeout:5000
})
// 掛在全局對(duì)象
instance.defaults.baseUrl = "";
instance.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
// 攔截器:請(qǐng)求攔截和響應(yīng)攔截 post請(qǐng)求參數(shù)需要轉(zhuǎn)碼
// axios的返回值對(duì)象要求是一個(gè)promise對(duì)象
instance.interceptors.request.use(config =>{
if(config.method === "post"){
config.data = qs.stringify(config.data)
}
if(store.state.token){
config.headers.authorization = store.state.token;
}
return config;
},error => Promise.reject(error))
instance.interceptors.response.use(
// 成功
response => response.status === 200 ? Promise.resolve(response) :Promise.reject(response),
// 失敗
error => {
const { response } = error;
if(response){
errroHandle(response.status,response.data)
return Promise.reject(response)
}else{
// 錯(cuò)誤信息都無(wú)法返回
console.log("請(qǐng)求被中斷");
}
}
)
export default instance
總結(jié)
以上所述是小編給大家介紹的封裝一下vue中的axios示例代碼詳解,希望對(duì)大家有所幫助!
相關(guān)文章
vue實(shí)現(xiàn)自定義樹(shù)形組件的示例代碼
這篇文章主要介紹了vue實(shí)現(xiàn)自定義樹(shù)形組件的示例代碼,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-08-08
vue2.x element-ui實(shí)現(xiàn)pc端購(gòu)物車頁(yè)面demo
這篇文章主要為大家介紹了vue2.x element-ui實(shí)現(xiàn)pc端購(gòu)物車頁(yè)面demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
vue展示dicom文件醫(yī)療系統(tǒng)的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue展示dicom文件醫(yī)療系統(tǒng)的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒加載,需要的朋友可以參考下2018-08-08
vue微信分享出來(lái)的鏈接點(diǎn)開(kāi)是首頁(yè)問(wèn)題的解決方法
這篇文章主要為大家詳細(xì)介紹了vue微信分享出來(lái)的鏈接點(diǎn)開(kāi)是首頁(yè)問(wèn)題的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11
純JS如何實(shí)現(xiàn)vue.js下的雙向綁定功能
對(duì)于vue下的雙向綁定功能,個(gè)人理解為在處理邏輯的過(guò)程中緩存了大量的node對(duì)象,node對(duì)象可以是html標(biāo)簽、文本內(nèi)容。既然選擇了緩存這些對(duì)象,那么在用的過(guò)程中哪里需要改變就把node拿出來(lái),進(jìn)行標(biāo)簽屬性的變更或者文本內(nèi)容的修改。本文主要講了如何實(shí)現(xiàn)雙向綁定2021-06-06
Vue封裝localStorage設(shè)置過(guò)期時(shí)間的示例詳解
這篇文章主要介紹了Vue封裝localStorage設(shè)置過(guò)期時(shí)間的相關(guān)資料,在這個(gè)示例中,我們?cè)贛yComponent.vue組件的setup函數(shù)中導(dǎo)入了setItemWithExpiry和getItemWithExpiry函數(shù),并在函數(shù)內(nèi)部使用它們來(lái)設(shè)置和獲取帶有過(guò)期時(shí)間的localStorage數(shù)據(jù),需要的朋友可以參考下2024-06-06

