js中的错误监控(一)【promise,async,generator异步+内置错误类型】的错误捕获与上报

相关博客:

js中的错误监控(一)【promise,async,generator异步+内置错误类型】的错误捕获与上报
js中的错误监控(二)【网络+资源加载】的错误捕获与上报


一、错误类型

主要分成两类——代码运行错误资源请求错误

1.代码运行错误

运行代码时发生的错误有非常多。每种错误都有相应的错误类型。ECMA-262定义了7种错误类型:

1.Error 错误,通用的异常对象。

Error是基类型。其它类型继承自它。我们通常使用Error来自定义异常,Error对象有name和message属性,可以通过message来得到具体的错误信息,比如

let error = new Error('接口报错');
let name = error.name; // 'Error'
let msg = error.message;    // '接口报错'

2.EvalError 调用eval()函数抛出错误

3.RangeError 引用错误

超出指定范围错误,比如声明一个负数的数组,使用toFixec超过了规定小数的位数(0-20)

new Array(-1)
(1.2).toFixed(21)

4.ReferenceError 參数错误,访问未定义的变量

function foo() {
   
    bar++;    // bar未定义
}

5.SyntaxError 语法错误,一般代码语句不完整

let a = 1 > 0 ?    // 正则不完整
if (a) {
            // 少了一个分号

6.TypeError 类型错误,一个变量不是函数,却把它当做函数来调用

let a = 1;
a();    // 类型错误

7.URIError 编码错误,在使用encodeURI()和decodeURI()时。假设URI格式不对时,会导致URIError错误。

encodeURI('\uD800')
encodeURIComponent('\uD800')
2.资源加载错误

这个错误通常是找不到文件(404)或者是文件加载超时造成的。
详见:
js中的错误监控(二)【网络+资源加载】的错误捕获与上报

二、错误冒泡

错误也具有冒泡传播性
如果在一个函数内部发生了错误,它自身没有捕获,错误就会被抛到外层调用函数,如果外层函数也没有捕获,该错误会一直沿着函数调用链向上抛出,直到被JavaScript引擎捕获,代码终止执行。
所以,我们不必在每一个函数内部捕获错误,只需要在合适的地方来个统一捕获,一网打尽

三、捕获代码错误

比如语法错误、逻辑错误,针对不会被代码检查插件发现的错误

1. try…catch语句

我们可以通过try/catch语法来捕捉错误。最常用的是在函数里面捕捉错误,有错误就在catch处理。

try {
   
  throw new Error("接口错误");
  console.log("try错误后面的语句不会被执行");
} catch (error) {
   
  // 捕获错误
  console.log("try-catch捕获", error);
} finally {
   
  //finally为了防止出现异常后。无法往下再运行的备用。
  console.log("finally 我都会运行!");
}
console.log("try-catch后面的语句");

控制台:
在这里插入图片描述

捕捉内置对象类型:

//try-catch
try 
  // 运行可能出错的代码
  a++;
  console.log("try错误后面的语句不会被执行");
} catch (error) {
   
  // 捕获错误
  console.log("try-catch捕获", error);
}
console.log("try-catch后面的语句");

控制台:

在这里插入图片描述
只有一个message信息量较少,可以通过新建一个自动义错误类,可以拿到出错的信息,堆栈,出错的文件、行号、列号;
捕捉自定义error:

// Create a custom error
var SpecifiedError = function SpecifiedError(</
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 使用异步函数是不会逃脱 express app.use 函数的捕获错误机制的。 在 express ,app.use 函数用于添加间件函数,这些函数会在请求和响应的生命周期被调用。如果在这些函数抛出了错误,那么 express 会捕获这个错误并将其传递给错误处理间件。 因此,无论是同步函数还是异步函数,都不会逃脱 express app.use 函数的捕获错误机制。如果你在 app.use 函数使用了异步函数,那么只需要在函数内部使用 try-catch 语句或者在函数最后使用 await 来捕获并处理异步操作可能出现的错误即可。 ### 回答2: 在Express,通过app.use函数注册的间件会自动捕获发生在其内部的同步错误,并通过next函数将错误传递给错误处理间件进行处理。这种错误捕获机制可以有效地处理同步错误。然而,对于异步函数,Express的错误处理机制是无法自动捕获并处理的。 使用异步函数时,如果在异步函数内部发生错误,Express的错误处理机制将无法捕获到这些错误,也无法进行相应的处理。这是因为异步函数的执行是非阻塞的,它们会立即返回一个Promise对象,并在后台执行。在这种情况下,错误发生在异步函数内部,而Express的错误处理机制在异步函数返回Promise对象后已经无法获取到这些错误。 为了解决这个问题,我们可以使用try/catch语句来捕获异步函数内部的错误,并手动调用next函数传递错误。这样,错误将被传递到下一个错误处理间件进行处理。 示例代码如下: app.use(async (req, res, next) => { try { // 异步操作 await someAsyncFunction(); next(); } catch (err) { next(err); } }); 上述代码,我们使用了async/await语法来处理异步函数,然后在try块执行异步操作,如果发生错误,则通过next函数将错误传递给下一个错误处理间件进行处理。 综上所述,使用异步函数时,需要手动处理其发生的错误,通过try/catch语句捕获错误并调用next函数传递错误,以便Express能够正确地处理它们。 ### 回答3: 使用异步函数不会逃脱express`app.use`函数的捕获错误的机制。 在Express,通过定义间件函数来处理HTTP请求,这些间件函数可以是同步的,也可以是异步的。无论是同步还是异步间件函数,Express都会在调用它们时使用try-catch块来捕获可能出现的错误。 在异步函数,当出现错误时,如果没有使用try-catch语句来显式地捕获错误,这些错误将会被自动转发到错误处理间件错误处理间件是一个专门用来处理错误间件函数,可以用`app.use`或`app.use(errorHandler)`方式来定义。因此,无论是同步的还是异步的函数,只要在处理请求的过程出现错误,Express都会通过错误处理间件来捕获和处理这些错误。 例如,下面是一个使用异步函数的Express间件的示例: ``` app.use(async (req, res, next) => { try { // 异步操作 await someAsyncFunction(); // 继续处理请求 next(); } catch (err) { // 错误处理 next(err); } }); ``` 在上述示例,`someAsyncFunction`是一个异步函数,当它抛出一个错误时,try-catch块会捕获这个错误并通过`next(err)`将其传递给错误处理间件进行处理。 总之,无论使用同步还是异步函数,Express都会捕获这些函数可能抛出的错误,并通过错误处理间件来处理这些错误,使得我们能够更好地处理和管理错误

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值