欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

前端項(xiàng)目中報(bào)錯(cuò)Uncaught?(in?promise)的解決方法

 更新時(shí)間:2023年04月23日 12:09:32   作者:pony君  
最近在做項(xiàng)目的時(shí)候控制臺(tái)報(bào)了一個(gè)錯(cuò)Uncaught(in promise) false,這篇文章主要給大家介紹了關(guān)于前端項(xiàng)目中報(bào)錯(cuò)Uncaught?(in?promise)的解決方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

項(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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js實(shí)現(xiàn)瀑布流觸底動(dòng)態(tài)加載數(shù)據(jù)

    js實(shí)現(xiàn)瀑布流觸底動(dòng)態(tài)加載數(shù)據(jù)

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)瀑布流觸底動(dòng)態(tài)加載數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 通過(guò)seajs實(shí)現(xiàn)JavaScript的模塊開(kāi)發(fā)及按模塊加載

    通過(guò)seajs實(shí)現(xiàn)JavaScript的模塊開(kāi)發(fā)及按模塊加載

    seajs實(shí)現(xiàn)了JavaScript 的 模塊開(kāi)發(fā)及按模塊加載。用來(lái)解決繁瑣的js命名沖突,文件依賴等問(wèn)題,其主要目的是令JavaScript開(kāi)發(fā)模塊化并可以輕松愉悅進(jìn)行加載。下面我們來(lái)一起深入學(xué)習(xí)下吧
    2019-06-06
  • big.js?如何解決精度丟失問(wèn)題源碼解析

    big.js?如何解決精度丟失問(wèn)題源碼解析

    這篇文章主要為大家介紹了big.js?如何解決精度丟失問(wèn)題源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • js實(shí)時(shí)獲取窗口大小變化的實(shí)例代碼

    js實(shí)時(shí)獲取窗口大小變化的實(shí)例代碼

    下面小編就為大家?guī)?lái)一篇js實(shí)時(shí)獲取窗口大小變化的實(shí)例代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11
  • 一道常被人輕視的web前端常見(jiàn)面試題(JS)

    一道常被人輕視的web前端常見(jiàn)面試題(JS)

    面試題是招聘公司和開(kāi)發(fā)者都非常關(guān)心的話題,公司希望通過(guò)它了解開(kāi)發(fā)者的真實(shí)水平和細(xì)節(jié)處理能力,而開(kāi)發(fā)者希望能夠最大程度地展示自己的水平(甚至超常發(fā)揮)。本文提供了眾多前端開(kāi)發(fā)面試題,無(wú)論是招聘方還是應(yīng)聘方都值得一看
    2016-02-02
  • JSONP跨域請(qǐng)求

    JSONP跨域請(qǐng)求

    本文主要介紹了jsonp跨域請(qǐng)求的相關(guān)知識(shí)。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-03-03
  • JavaScript中對(duì)象property的讀取和寫(xiě)入方法介紹

    JavaScript中對(duì)象property的讀取和寫(xiě)入方法介紹

    這篇文章主要介紹了JavaScript中對(duì)象property的讀取和寫(xiě)入方法介紹,本文講解了原型繼承鏈中property的讀取、原型繼承鏈中property的寫(xiě)入等內(nèi)容,需要的朋友可以參考下
    2014-12-12
  • sass 中使用 /deep/ 修改 elementUI 組件樣式報(bào)錯(cuò)的解決方案

    sass 中使用 /deep/ 修改 elementUI 組件樣式報(bào)錯(cuò)

    這篇文章主要介紹了sass 中使用 /deep/ 修改 elementUI 組件樣式報(bào)錯(cuò)的解決方案,嘗試用 ::v-deep 替換 /deep/ ,成功解決了問(wèn)題,感興趣的朋友跟隨小編一起看看吧
    2024-02-02
  • JavaScript中offsetWidth的bug及解決方法

    JavaScript中offsetWidth的bug及解決方法

    這篇文章主要為大家詳細(xì)介紹了JavaScript中offsetWidth的bug及解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • Web性能優(yōu)化系列 10個(gè)提升JavaScript性能的技巧

    Web性能優(yōu)化系列 10個(gè)提升JavaScript性能的技巧

    Javascript 性能優(yōu)化絕不是一種書(shū)面的技術(shù),Nicholas 的技術(shù)演進(jìn)列出了10條建議,幫助你寫(xiě)出高效的 JS 代碼
    2016-09-09

最新評(píng)論