每日一题之实现一个new

91 阅读1分钟

要实现一个new, 就要知道new内部发生了什么

  1. 创建一个空对象
  2. 将新创建的对象的原型链接到构造函数的原型对象上
  3. 将构造函数的作用域赋值给新创建的对象(因此 this指向了新对象)
  4. 执行构造函数内部的代码, 以初始化对象的属性和方法
  5. 如果构造函数没有显式的返回一个对象, 则返回新创建的对象
  • 代码实现
function myNew(constructor, ...args) {
  const obj = {};
  Object.setPrototypeOf(obj, constructor.prototype);
  const result = constructor.apply(obj, args);
  return result instanceof Object ? result : obj;
}

function Person(name, age) {
  this.name = name;
  this.age = age;
}

Person.prototype.greet = function () {
  console.log(`Hello, my name is ${this.name} and I am ${this.age}`);
};

const john = myNew(Person, "John", 25);
john.greet();