JavaScript异步代码中try…catch失效:为什么我的异步函数异常没有被捕获?

关于javascript异步代码中try…catch语句失效的问题

javascript开发中,正确处理异步操作中的错误至关重要。本文将针对一个案例,分析为什么try…catch语句在异步代码中未能捕获异常。

问题描述:一段代码中,refreshdata函数包含一个try…catch块,用于处理refreshtoken函数可能抛出的错误。然而,即使refreshtoken函数发生错误,catch块也没有被执行。

代码片段如下:

let isrefreshtoken = falseconst request = (url:string, method:string, data?:any) => {  return new promise(async (resolve, reject) => {    if (isrefreshtoken) return    // 判断token超时,刷新token    if (store.getters.expirestime && new date().gettime() >= store.getters.expirestime) {      await refreshdata()      return    }    ...}const refreshdata = async () => {  if (!isrefreshtoken) {    isrefreshtoken = true    if (!store.getters.refertoken) {      cleandata()      isrefreshtoken = false    } else {      console.log(123);      try {        let res = await refreshtoken(store.getters.refertoken)         store.dispatch('saveinfo', res)          isrefreshtoken = false          uni.switchtab({ url: '/pages/device/index' })      } catch (error) {        cleandata()      }      console.log(333);    }  }}

登录后复制

问题在于request函数内部使用了new promise(async (resolve, reject) => { … })这种方式。async函数内部的await会暂停执行,但并不会将refreshdata函数内部的异常传递给promise的reject函数。

立即学习“Java免费学习笔记(深入)”;

解决方案:

有两种方式可以解决这个问题:

第一种方式:将request函数声明为async函数,直接使用await调用refreshdata,这样refreshdata中发生的异常会自动向上冒泡,并被await捕获。

const request = async (url: string, method: string, data?: any) => {    if (isrefreshtoken) return    // 判断token超时,刷新token    if (store.getters.expirestime && new date().gettime() >= store.getters.expirestime) {        await refreshdata()        return    }}

登录后复制

第二种方式:如果必须使用new promise,则需要在refreshdata函数执行完毕后,通过then和catch方法来处理refreshdata的返回结果和异常。

const request = (url: string, method: string, data?: any): Promise => {    return new Promise((resolve, reject) => {        if (isRefreshToken) return        // 判断token超时,刷新token        if (Store.getters.expiresTime && new Date().getTime() >= Store.getters.expiresTime) {            refreshData().then(resolve, reject);            return        }    });}

登录后复制

需要注意的是,这两种方法都是处理异步错误的方式,并不是同步代码。 await 只是异步编程中的语法糖,它并不能改变异步操作的本质。

以上就是JavaScript异步代码中try…catch失效:为什么我的异步函数异常没有被捕获?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3044717.html

(0)
上一篇 2025年3月13日 15:29:34
下一篇 2025年2月27日 12:14:54

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论