javascript – 如何挂钩/猴子补丁基本的错误类

前端之家收集整理的这篇文章主要介绍了javascript – 如何挂钩/猴子补丁基本的错误类前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我如何“修补”(或替换)基本的错误类,以便任何人在代码库中抛出新的Error()(或尝试抛出任何派生自Error的东西)实际实例化的是一些替换class(有一些额外的字段,逻辑).

我确实意识到这远非一种最佳实践,并不适用于典型的JS开发场景,它适用于运行任意用户代码的沙盒环境.

我试过这样的东西(没用):

OurError.prototype = Object.create(Error.prototype);
Error.prototype = OurError.prototype;

很明显,我对原型知之甚少,无法理解我在做什么.会欣赏一些指针或一个简单的例子.@H_301_14@

最佳答案@H_301_14@
您总是可以向Error.prototype添加更多方法,然后使用它们,就像这样(在ES6中):

Error.prototype.hello = function() {
  console.log(`Hello from ${this.constructor.name}!`);
}

const a = new Error();
a.hello(); // outputs "Hello from Error"

class MyError extends Error {};

const b = new MyError();
b.hello(); // outputs "Hello from MyError"

您也可以像这样完全替换Error类:

class ImprovedError {
  constructor() {
    console.log(`I am an ${this.constructor.name}!`);
  }
};

Error = ImprovedError;
const c = new Error(); // outputs "I am an ImprovedError"

请注意,在与外部依赖项(库)交互时,完全替换Error类可能会产生一些不良后果和不可预测的结果,因为它们可能期望并调用原始Error类的方法.

有关Error类方法和行为see here的更多信息@H_301_14@

猜你在找的JavaScript相关文章