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的实现的主要内容,如果未能解决你的问题,请参考以下文章
高频重要前端API手写整理(call,apply,bind,instanceof,flat,filter,new,防抖,节流,深浅拷贝,数组乱序,数组去重,继承, lazyman,jsonp的实现,函