前端項(xiàng)目中報(bào)錯(cuò)Uncaught?(in?promise)的解決方法
項(xiàng)目中報(bào)錯(cuò) Uncaught (in promise)
一、問(wèn)題:當(dāng)你調(diào)用 Promise.reject() 回調(diào)的時(shí)候,Chrome 控制臺(tái)中出現(xiàn)一條警告消息“Uncaught (in promise)”。
例如你簡(jiǎn)單封裝axios的響應(yīng)攔截器的時(shí)候:
// 響應(yīng)攔截
service.interceptors.response.use((res)=>{
const code:number=res.data.data.code
if(code!=200){
return Promise.reject(res.data.data.msg)
}
return res.data.data
},(err)=>{
console.log(err);
})
以一個(gè)登錄提交的方法為例,當(dāng)你只使用.then,并且走到了 return Promise.reject() 的區(qū)間:
(我是在學(xué)ts的時(shí)候遇到的,如果你是在js里面遇到問(wèn)題的話,只需要把類(lèi)型去掉看就可以了)
const submitForm = (formEl: FormInstance | undefined) => {
if (!formEl) return;
formEl.validate((valid) => {
if (valid) {
login(data.ruleForm).then((res:object)=>{
console.log(res);
})
} else {
console.log("error submit!");
return false;
}
});
};
控制臺(tái)錯(cuò)誤如圖:

二、原因:發(fā)生這種情況就是因?yàn)槟鷽](méi)有將捕獲處理程序附加到 then 返回的 promise 中方法,因此在 promise 拒絕時(shí)沒(méi)有處理程序。
如果onRejected處理程序沒(méi)有顯式地提供給.then(onResolved, onRejected)方法,JS會(huì)自動(dòng)提供一個(gè)隱式的。它看起來(lái)是這樣的:(err) => throw err。自動(dòng)生成的處理程序?qū)⒃谄浠睾现袙伋觥?/p>
在 promise 鏈中,可以使用 catch 捕獲此錯(cuò)誤方法回調(diào),但如果不存在,JavaScript 引擎將像處理任何其他 Uncaught Error 一樣處理錯(cuò)誤,并在這種情況下應(yīng)用默認(rèn)處理程序,這會(huì)導(dǎo)致您在控制臺(tái)中看到輸出。
三、處理方法:只需要在調(diào)用的時(shí)候在.then后面加上.catch對(duì)異常情況進(jìn)行捕獲并進(jìn)行處理即可。
還是上面那個(gè)登錄方法
1.這是使用.then的處理方法
const submitForm = (formEl: FormInstance | undefined) => {
if (!formEl) return;
formEl.validate((valid) => {
if (valid) {
login(data.ruleForm).then((res:object)=>{
console.log(res);
})
.catch((err:any)=>{
console.log(err);
})
} else {
console.log("error submit!");
return false;
}
});
};
2.這是使用 async 和 await 進(jìn)行修飾的處理方法(需要用到 try catch)
const submitForm = (formEl: FormInstance | undefined) => {
if (!formEl) return;
formEl.validate(async (valid) => {
if (valid) {
try{
let res = await login(data.ruleForm)
console.log(res);
}catch(err:any){
console.log(err);
}
} else {
console.log("error submit!");
return false;
}
})
};
此時(shí)控制臺(tái)輸出的就是你的處理結(jié)果,不會(huì)再出現(xiàn) Uncaught (in promise) 了。

參考:https://stackoverflow.com/questions/42460039/promise-reject-causes-uncaught-in-promise-warning
總結(jié)
到此這篇關(guān)于前端項(xiàng)目中報(bào)錯(cuò)Uncaught(in promise)解決的文章就介紹到這了,更多相關(guān)前端報(bào)錯(cuò)Uncaught(in promise)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- JS報(bào)錯(cuò)Uncaught?TypeError:?XXX?is?not?a?function的解決方法
- 關(guān)于Uncaught(in?promise)TypeError:?list?is?not?iterable報(bào)錯(cuò)解決
- js控制臺(tái)報(bào)錯(cuò)Uncaught TypeError: Cannot read properties of undefined (reading ‘a(chǎn)ppendChild‘)的解決
- Uncaught EvalError:Refused to evaluate a string as JavaScript解決
相關(guān)文章
nuxtjs通過(guò)ecosystem.config.js配置pm2的方法
ecosystem.config.js 是一個(gè)特殊的配置文件,它允許您定義應(yīng)用的各種屬性,如腳本路徑、環(huán)境變量、日志設(shè)置等,這篇文章主要介紹了nuxtjs通過(guò)ecosystem.config.js配置pm2的方法,需要的朋友可以參考下2024-03-03
詳細(xì)教你微信公眾號(hào)正文頁(yè)SVG交互開(kāi)發(fā)技巧
這篇文章主要介紹了詳細(xì)教你微信公眾號(hào)正文頁(yè)SVG交互開(kāi)發(fā)技巧,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
深入理解javascript動(dòng)態(tài)插入技術(shù)
這篇文章介紹了javascript動(dòng)態(tài)插入技術(shù),有需要的朋友可以參考一下2013-11-11
JavaScript深拷貝的幾種實(shí)現(xiàn)方法實(shí)例
javascript深拷貝是初學(xué)者甚至有經(jīng)驗(yàn)的開(kāi)發(fā)著,都會(huì)經(jīng)常遇到問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于JavaScript深拷貝的幾種實(shí)現(xiàn)方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05
javascript中的undefined和not defined區(qū)別示例介紹
這篇文章主要介紹了javascript中的undefined和not defined區(qū)別,需要的朋友可以參考下2014-02-02
JavaScript實(shí)現(xiàn)搜索聯(lián)想關(guān)鍵字高亮功能
本文將詳解如何利用原生js+css+html實(shí)現(xiàn)的輸入框搜索聯(lián)想的功能,并集搜索關(guān)鍵字高亮效果,文中的示例代碼講解詳細(xì),需要的可以參考一下2022-06-06
JS優(yōu)化與惰性載入函數(shù)實(shí)例分析
這篇文章主要介紹了JS優(yōu)化與惰性載入函數(shù),結(jié)合具體實(shí)例形式分析了JS惰性載入的原理、實(shí)現(xiàn)技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-04-04
JavaScript中對(duì)象的不同創(chuàng)建方法
js對(duì)象與一般的面向?qū)ο蟮某绦蛟O(shè)計(jì)語(yǔ)言有所不同的。js中的對(duì)象是基本原型的。下面給大家介紹js中對(duì)象的不同創(chuàng)建方法,非常不錯(cuò),感興趣的朋友一起學(xué)習(xí)吧2016-08-08
JavaScript實(shí)現(xiàn)淘寶購(gòu)物件數(shù)選擇
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)淘寶購(gòu)物件數(shù)的選擇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08

