色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

vue axios請求成功卻進入catch的原因分析

瀏覽:85日期:2022-11-27 09:44:38

問題:axios返回200狀態碼(即請求成功)卻走進了catch里面

原因:

1.當axios請求完成后走的時then的代碼塊,如果then代碼塊中存在錯誤代碼信息,這時就會進入catch中拋出異常(注意:此時控制臺并不會報錯,因為錯誤被catch捕獲了

2.axios是異步發起,若發起后頁面刷新,那么就會丟失當前進程,導致接收不到。例如 form表單,點擊按鈕提交后,表單會刷新

補充知識:axios用catch的寫法與不使用catch有什么區別?

官網上的寫法:

axios.post(url, data) .then(response => { console.log(response); }) .catch(error => { console.log(error); })

公司項目的寫法:

axios.post(url, data) .then(response => { console.log(response); }, error => { console.log(error); })

之前一直沒有仔細研究過then和catch的寫法,事實上,這個不是 axios catch 的相關 而是關于 new Promise() 的then

阮一峰在 promise 文檔中有介紹。

一般來說,不要在then方法里面定義 Reject 狀態的回調函數(即then的第二個參數),總是使用catch方法。

// badpromise .then(function(data) { // success }, function(err) { // error });// goodpromise .then(function(data) { //cb // success }) .catch(function(err) { // error });

上面代碼中,第二種寫法要好于第一種寫法,理由是第二種寫法可以捕獲前面then方法執行中的錯誤,也更接近同步的寫法(try/catch)。因此,建議總是使用catch方法,而不使用then方法的第二個參數。

公司的寫法無法catch第一個參數的異常。

這樣寫可能容易看懂一些:

axios.post(url, data) .then(response => { //處理邏輯 }, error => { console.log(’接口報錯’); }) .catch(error=>{ console.log(’處理邏輯出錯’); })

axios.post(url, data) .then(response => { //處理邏輯 }) .catch(error=>{ console.log(’接口或處理邏輯出錯’); })

以上這篇vue axios請求成功卻進入catch的原因分析就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: IOS
相關文章:
主站蜘蛛池模板: 手机看成人免费大片 | 欧美一级特黄做 | 国产视频自拍一区 | 女高中生被cao到哭视频 | 蝴蝶成人世界第八影院 | 亚洲精品成人一区二区 | 精品国产免费观看久久久 | 色吊丝avav色吊丝 | 亚洲网站视频在线观看 | 一区二区三区久久 | 成人黄色免费看 | 美女张开腿男人桶 | 免费观看欧美一级毛片 | 精品国产免费一区二区三区 | 国产亚洲精品成人久久网站 | 88av视频在线观看 | 亚洲影院手机版777点击进入影院 | 亚洲男女视频 | 国产精品合集一区二区 | 亚洲视频免费一区 | 欧美野外性k8播放性迷宫 | 欧美色视频在线观看 | 日韩精品一区二区三区在线观看 | 国产成人夜间影院在线观看 | 亚洲午夜久久 | 欧美高清一区二区三区欧美 | 亚洲精品国产成人专区 | 日韩免费精品一级毛片 | 欧美一级一一特黄 | 亚洲人成影院午夜网站 | 荡公乱妇蒂芙尼中文字幕 | 亚洲成人黄色在线观看 | 国产日韩在线视频 | 男女超猛烈啪啦啦的免费视频 | 午夜免费的国产片在线观看 | 欧美日韩在线视频观看 | 成人三级做爰在线观看男女 | 天天看有黄有色大片 | 91aaa免费免费国产在线观看 | 男女午夜 | 玖玖精品国产 |