91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

web前端項目中報錯Uncaught?(in?promise)怎么解決

發布時間:2023-04-24 15:19:07 來源:億速云 閱讀:965 作者:iii 欄目:開發技術

今天小編給大家分享一下web前端項目中報錯Uncaught (in promise)怎么解決的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

一、問題:當你調用 Promise.reject() 回調的時候,Chrome 控制臺中出現一條警告消息“Uncaught (in promise)”。

例如你簡單封裝axios的響應攔截器的時候:

// 響應攔截
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);
})

以一個登錄提交的方法為例,當你只使用.then,并且走到了 return Promise.reject() 的區間:

(我是在學ts的時候遇到的,如果你是在js里面遇到問題的話,只需要把類型去掉看就可以了)

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;
        }
      });
    };

控制臺錯誤如圖:

web前端項目中報錯Uncaught?(in?promise)怎么解決

二、原因:發生這種情況就是因為您沒有將捕獲處理程序附加到 then 返回的 promise 中方法,因此在 promise 拒絕時沒有處理程序。

如果onRejected處理程序沒有顯式地提供給.then(onResolved, onRejected)方法,JS會自動提供一個隱式的。它看起來是這樣的:(err) => throw err。自動生成的處理程序將在其回合中拋出。

在 promise 鏈中,可以使用 catch 捕獲此錯誤方法回調,但如果不存在,JavaScript 引擎將像處理任何其他 Uncaught Error 一樣處理錯誤,并在這種情況下應用默認處理程序,這會導致您在控制臺中看到輸出。

三、處理方法:只需要在調用的時候在.then后面加上.catch對異常情況進行捕獲并進行處理即可。

還是上面那個登錄方法

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 進行修飾的處理方法(需要用到 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;
        }
      })
      
    };

此時控制臺輸出的就是你的處理結果,不會再出現 Uncaught (in promise) 了。

web前端項目中報錯Uncaught?(in?promise)怎么解決

以上就是“web前端項目中報錯Uncaught (in promise)怎么解決”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

太原市| 小金县| 平乡县| 周至县| 东乌珠穆沁旗| 龙游县| 迁安市| 金塔县| 宜阳县| 泊头市| 临沭县| 武功县| 富阳市| 丹棱县| 武强县| 逊克县| 阳山县| 马山县| 榕江县| 雷波县| 古蔺县| 桂阳县| 富蕴县| 台南县| 开封市| 靖州| 神木县| 广河县| 湄潭县| 凉城县| 渝中区| 和静县| 安阳市| 庆阳市| 肇州县| 南涧| 田东县| 平凉市| 章丘市| 天柱县| 吴桥县|