vue axios請(qǐng)求成功卻進(jìn)入catch的原因分析
問(wèn)題:axios返回200狀態(tài)碼(即請(qǐng)求成功)卻走進(jìn)了catch里面
原因:
1.當(dāng)axios請(qǐng)求完成后走的時(shí)then的代碼塊,如果then代碼塊中存在錯(cuò)誤代碼信息,這時(shí)就會(huì)進(jìn)入catch中拋出異常(注意:此時(shí)控制臺(tái)并不會(huì)報(bào)錯(cuò),因?yàn)殄e(cuò)誤被catch捕獲了)
2.axios是異步發(fā)起,若發(fā)起后頁(yè)面刷新,那么就會(huì)丟失當(dāng)前進(jìn)程,導(dǎo)致接收不到。例如 form表單,點(diǎn)擊按鈕提交后,表單會(huì)刷新
補(bǔ)充知識(shí):axios用catch的寫(xiě)法與不使用catch有什么區(qū)別?
官網(wǎng)上的寫(xiě)法:
axios.post(url, data) .then(response => { console.log(response); }) .catch(error => { console.log(error); })
公司項(xiàng)目的寫(xiě)法:
axios.post(url, data) .then(response => { console.log(response); }, error => { console.log(error); })
之前一直沒(méi)有仔細(xì)研究過(guò)then和catch的寫(xiě)法,事實(shí)上,這個(gè)不是 axios catch 的相關(guān) 而是關(guān)于 new Promise() 的then
阮一峰在 promise 文檔中有介紹。
一般來(lái)說(shuō),不要在then方法里面定義 Reject 狀態(tài)的回調(diào)函數(shù)(即then的第二個(gè)參數(shù)),總是使用catch方法。
// badpromise .then(function(data) { // success }, function(err) { // error });// goodpromise .then(function(data) { //cb // success }) .catch(function(err) { // error });
上面代碼中,第二種寫(xiě)法要好于第一種寫(xiě)法,理由是第二種寫(xiě)法可以捕獲前面then方法執(zhí)行中的錯(cuò)誤,也更接近同步的寫(xiě)法(try/catch)。因此,建議總是使用catch方法,而不使用then方法的第二個(gè)參數(shù)。
公司的寫(xiě)法無(wú)法catch第一個(gè)參數(shù)的異常。
這樣寫(xiě)可能容易看懂一些:
axios.post(url, data) .then(response => { //處理邏輯 }, error => { console.log(’接口報(bào)錯(cuò)’); }) .catch(error=>{ console.log(’處理邏輯出錯(cuò)’); })
axios.post(url, data) .then(response => { //處理邏輯 }) .catch(error=>{ console.log(’接口或處理邏輯出錯(cuò)’); })
以上這篇vue axios請(qǐng)求成功卻進(jìn)入catch的原因分析就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. php使用正則驗(yàn)證密碼字段的復(fù)雜強(qiáng)度原理詳細(xì)講解 原創(chuàng)2. 基于PHP做個(gè)圖片防盜鏈3. jscript與vbscript 操作XML元素屬性的代碼4. Jsp+Servlet實(shí)現(xiàn)文件上傳下載 文件列表展示(二)5. XML在語(yǔ)音合成中的應(yīng)用6. Jsp servlet驗(yàn)證碼工具類(lèi)分享7. ASP將數(shù)字轉(zhuǎn)中文數(shù)字(大寫(xiě)金額)的函數(shù)8. asp.net core 認(rèn)證和授權(quán)實(shí)例詳解9. 基于javaweb+jsp實(shí)現(xiàn)企業(yè)車(chē)輛管理系統(tǒng)10. HTML5實(shí)戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)
