javascript - 检查构造函数是否继承了 ES6 中的另一个构造函数

标签 javascript ecmascript-6 prototypal-inheritance

我有一种情况需要检查构造函数 (X) 在其原型(prototype)链中是否有另一个构造函数 (Y)(或者是 Y 本身)。

最快的方法可能是 (new X()) instanceof Y。在这种情况下,这不是一个选项,因为如果在没有有效参数的情况下实例化,所讨论的构造函数可能会抛出异常。

我考虑的下一个方法是:

const doesInherit = (A, B) => {
  while (A) {
    if (A === B) return true;
    A = Object.getPrototypeOf(A);
  }

  return false;
}

这行得通,但我无法摆脱这样一种感觉,即我错过了一些更直接的方法来检查它。有吗?

最佳答案

由于 instanceof 的工作方式,您应该能够做到

A.prototype instanceof B

但这只会测试继承,你应该比较 A === B 来测试自引用:

A === B || A.prototype instanceof B

Babel example :

class A {}
class B extends A {}
class C extends B {}

console.log(C === C) // true
console.log(C.prototype instanceof B) // true
console.log(C.prototype instanceof A) // true

instanceof基本实现如下:

function instanceof(obj, Constr) {
  var proto;
  while ((proto = Object.getProtoypeOf(obj)) {
    if (proto === Constr.prototype) {
      return true;
    }
  }
  return false;
}

它遍历对象的原型(prototype)链并检查是否有任何原型(prototype)等于构造函数 prototype 属性。

几乎就像你在做的,但在内部。

关于javascript - 检查构造函数是否继承了 ES6 中的另一个构造函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30993434/

相关文章:

javascript - 使用 ngif 时 ngclass 的奇怪行为

javascript - 媒体记录器跨浏览器以 WAV 格式保存

javascript - 参数未知时的 Cypher MATCH 请求

javascript - Babelify 在从 node_modules 导入模块时抛出 ParseError

javascript - 原型(prototype)继承和instanceof

javascript - 哪种转换类型获取所有 Chrome 浏览历史记录?

c# - 启动脚本未触发

javascript - 扩展 Promise 基类类型

javascript - 在 JavaScript 中恢复无效函数

javascript - 我们应该使用 JavaScript 继承的哪些变体以及为什么?