JS new和instanceof的实现

Posted qq965921539

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS new和instanceof的实现相关的知识,希望对你有一定的参考价值。

function isObject(value) {
  const type = typeof value;
  return value !== null && (type === ‘object‘ || type === ‘function‘);
}

/**
 * constructor 表示 new 的构造器
 * args 表示传给构造器的参数
 */
function New(constructor, ...args) {
  // new 的对象不是函数就抛 TypeError
  if (typeof constructor !== ‘function‘) throw new TypeError(`${constructor} is not a constructor`);

  // 创建一个原型为构造器的 prototype 的空对象 target
  const target = Object.create(constructor.prototype);
  // 将构造器的 this 指向上一步创建的空对象,并执行,为了给 this 添加实例属性
  const result = constructor.apply(target, args);

  // 上一步的返回如果是对象就直接返回,否则返回 target
  return isObject(result) ? result : target;
}
function instanceOf(obj, constructor) {
  if (!isObject(constructor)) {
    throw new TypeError(`Right-hand side of ‘instanceof‘ is not an object`);
  } else if (typeof constructor !== ‘function‘) {
    throw new TypeError(`Right-hand side of ‘instanceof‘ is not callable`);
  }

  // 主要就这一句
  return constructor.prototype.isPrototypeOf(obj);
}

 

转自:https://juejin.im/post/5e2ff7dce51d4558021a1a4d

以上是关于JS new和instanceof的实现的主要内容,如果未能解决你的问题,请参考以下文章

instanceof和typeof运算符的区别详解

关于JS原型以及原型链instanceof的一些理解

js instanceof

typeof与instanceof区别

JS 原生方法原理探究:如何实现 instanceof?

高频重要前端API手写整理(call,apply,bind,instanceof,flat,filter,new,防抖,节流,深浅拷贝,数组乱序,数组去重,继承, lazyman,jsonp的实现,函