广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >如何捕获未处理的Promise错误方法
  • 341
分享到

如何捕获未处理的Promise错误方法

2024-04-02 19:04:59 341人浏览 独家记忆
摘要

小编给大家分享一下如何捕获未处理的Promise错误方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!为了保证可读性,本文采用意译而非直译,并且对源代码进行了大量修改。另外,本文版权归原作

小编给大家分享一下如何捕获未处理的Promise错误方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

为了保证可读性,本文采用意译而非直译,并且对源代码进行了大量修改。另外,本文版权归原作者所有,翻译仅用于学习。

使用Promise编写异步代码时,使用reject来处理错误。有时,开发者通常会忽略这一点,导致一些错误没有得到处理。例如:

function main() {
asyncFunc()
.then(···)
.then(() => console.log('Done!'));
}

由于没有使用catch方法捕获错误,当asyncFunc()函数reject时,抛出的错误则没有被处理。

这篇博客将分别介绍在浏览器与node.js中,如何捕获那些未处理的Promise错误。

浏览器中未处理的Promise错误

一些浏览器(例如Chrome)能够捕获未处理的Promise错误。

unhandledrejection

监听unhandledrejection事件,即可捕获到未处理的Promise错误:

window.addEventListener('unhandledrejection', event => ···);

这个事件是PromiseRejectionEvent实例,它有2个最重要的属性:

promise: reject的Promise

reason: Promise的reject值

示例代码:

window.addEventListener('unhandledrejection', event =>
{
console.log(event.reason); // 打印"Hello, Fundebug!"
});
 
function foo()
{
Promise.reject('Hello, Fundebug!');
}
 
foo();

Fundebug的javascript错误监控插件监听了unhandledrejection事件,因此可以自动捕获未处理Promise错误。

rejectionhandled

当一个Promise错误最初未被处理,但是稍后又得到了处理,则会触发rejectionhandled事件:

window.addEventListener('rejectionhandled', event => ···);

这个事件是PromiseRejectionEvent实例。

示例代码:

window.addEventListener('unhandledrejection', event =>
{
console.log(event.reason); // 打印"Hello, Fundebug!"
});
 
window.addEventListener('rejectionhandled', event =>
{
console.log('rejection handled'); // 1秒后打印"rejection handled"
});
 
 
function foo()
{
return Promise.reject('Hello, Fundebug!');
}
 
var r = foo();
 
setTimeout(() =>
{
r.catch(e =>{});
}, 1000);

Node.js中未处理的Promise错误

监听unhandledRejection事件,即可捕获到未处理的Promise错误:

process.on('unhandledRejection', (reason, promise) => ···);

示例代码:

process.on('unhandledRejection', reason =>
{
console.log(reason); // 打印"Hello, Fundebug!"
});
 
function foo()
{
Promise.reject('Hello, Fundebug!');
}
 
foo();

注: Node.js v6.6.0+ 默认会报告未处理的Promise错误,因此不去监听unhandledrejection事件也没问题。

Fundebug的node.js错误监控插件监听了unhandledRejection事件,因此可以自动捕获未处理Promise错误。

看完了这篇文章,相信你对“如何捕获未处理的Promise错误方法”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网VUE频道,感谢各位的阅读!

--结束END--

本文标题: 如何捕获未处理的Promise错误方法

本文链接: https://www.lsjlt.com/news/72888.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何捕获未处理的Promise错误方法
    小编给大家分享一下如何捕获未处理的Promise错误方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!为了保证可读性,本文采用意译而非直译,并且对源代码进行了大量修改。另外,本文版权归原作...
    99+
    2022-10-19
  • php curl 错误捕获的方法
    本文操作环境:Windows7系统、PHP7.1版、DELL G3电脑php curl 错误捕获的方法curl_error($ch) 用 curl_error 来获取 curl 的错误介绍:curl_error — 返回一个保护当前会话最近...
    99+
    2016-01-18
    php curl
  • php curl错误捕获的方法是什么
    本篇内容主要讲解“php curl错误捕获的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“php curl错误捕获的方法是什么”吧!php curl错误捕获的方法是通过curl_err...
    99+
    2023-06-25
  • PHP7中的错误处理机制:如何更好地管理和捕获错误?
    PHP7中的错误处理机制:如何更好地管理和捕获错误?引言:错误处理是编程中非常重要的一部分,它能够帮助我们更好地调试和管理代码。PHP7对错误处理机制进行了改进,提供了更多强大的功能和灵活性。本文将介绍如何在PHP7中更好地管理和捕获错误,...
    99+
    2023-10-22
    管理 PHP 捕获 错误处理
  • await/async无法捕获与处理错误信息的解决方案分享
    目录前言同步和异步异步任务所存在的问题Promise如何解决回调地狱async/await,回调地狱的最终方案async/await错误处理方案第一种,手动添加啊try{}catch...
    99+
    2023-02-03
    async await捕获错误 async await错误处理 async await用法
  • Go错误处理之panic函数和recover函数使用及捕获异常方法
    目录前言panic函数recover函数总结前言 前面我们讲过了error类型来处理一般的错误,本文会描述使用panic函数和recover函数来处理比较极端的错误。简单来说,当程序...
    99+
    2023-03-24
    go异常捕获panic recover go异常捕获 go panic函数使用
  • Python异常捕获和处理的方法是什么
    1 | 语法错误指解析代码时出现的错误。当代码不符合Python 语法规则时,Python解释器在解析时就会报出 SyntaxError 语法错误,与此同时还会明确指出最早探测到错误的语句。例如:print "Hello,Worl...
    99+
    2023-05-23
    Python
  • Python中异常捕获与处理的方法总结
    Python异常是在程序执行时发生的错误,可能会导致程序终止运行。 在Python中,异常处理是一种机制,它允许开发人员在程序发生异常时捕获、处理和报告这些异常,以便程序可以继续运行...
    99+
    2023-05-18
    Python异常捕获 Python异常处理 Python异常
  • java捕获空指针并处理的方法是什么
    在Java中,可以使用try-catch语句来捕获空指针异常并进行处理。具体的方法如下:1. 使用try-catch语句块捕获空指针...
    99+
    2023-08-21
    java
  • RestTemplate 401 获取错误信息的处理方案
    目录RestTemplate401错误异常处理判断是否异常RestTemplate通过对象传参,response的body为空讨论代码复现解决办法一:实体类转成普通类解决办法二:添加...
    99+
    2022-11-12
  • java中HttpClient的错误处理方法
    这篇“java中HttpClient的错误处理方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“java中HttpClien...
    99+
    2023-06-30
  • JavaScript常见的错误处理方法
    这篇文章主要介绍“JavaScript常见的错误处理方法”,在日常操作中,相信很多人在JavaScript常见的错误处理方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Ja...
    99+
    2022-10-19
  • javascript全局错误的处理方法
    这篇文章主要介绍了javascript全局错误的处理方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JavaScript是什么JavaScript是一种直译式的脚本语言,其...
    99+
    2023-06-14
  • mybatis错误处理的方法有哪些
    MyBatis 提供了以下几种错误处理的方法:1. 异常映射:MyBatis 可以将底层数据库访问引发的异常映射为应用程序定义的异常...
    99+
    2023-09-13
    mybatis
  • java错误处理的方法有哪些
    Java错误处理的方法有以下几种:1. 异常捕获和处理:使用try-catch语句来捕获和处理异常。在try块中编写可能抛出异常的代...
    99+
    2023-08-26
    java
  • Rust处理错误的方法是什么
    这篇文章主要介绍“Rust处理错误的方法是什么”,在日常操作中,相信很多人在Rust处理错误的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Rust处理错误的方法是什么”的疑惑有所帮助!接下来,请跟...
    99+
    2023-07-05
  • python错误处理的方法有哪些
    在Python中,常用的错误处理方法有以下几种: try-except语句:用于捕获和处理异常。代码放在try代码块中执行,如果...
    99+
    2023-10-26
    python
  • linux系统报tcp_mark_head_lost错误的处理方法
    问题说明 近期一台主机报以下 kernel 信息: Jul 8 10:47:42 cztest kernel: ------------[ cut here ]------------ Jul 8 10:47:42...
    99+
    2022-06-04
    linux tcp_mark_head_lost linux 系统错误检查
  • PHP中封装性的错误处理方法
    在PHP开发中,错误处理是一个至关重要的环节。封装性的错误处理方法可以提高代码的可维护性和可读性,同时也能提供更好的调试和报错能力。本文将介绍几种常见的错误处理方法,并给出具体的代码示例。使用try-catch块处理异常在PHP中,可以使用...
    99+
    2023-10-21
    PHP编程 错误处理 封装性
  • php7中异常与错误的处理方法
    这篇文章将为大家详细讲解有关php7中异常与错误的处理方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。异常与错误的概述什么叫做异常?异常是指程序运行中不符合预期情况以及与正常流程不同的状况。比如你链接数...
    99+
    2023-06-14
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作