JS的new做了什么?

我感觉手写个new就懂了其实~~

那么先写一个咯

  1. 创建一个给定构造函数的实例对象 -> 实例[[prototype]] = 构造函数.prototype
function myNew(constructorFn, ...args) {
  // 创建一个新的空对象,并连接原型链
  var obj = Object.create(constructorFn.prototype);
  // 将构造函数的 this 指向新对象,并执行构造函数
  var result = constructorFn.apply(obj, args);
  // 如果构造函数有显式返回一个对象,则返回该对象
  if (typeof result === 'object' && result !== null) {
    return result;
  }
  // 否则,返回新对象
  return obj;
}

为什么要呢?

因为如果要构造很多实例,那么实例之间又有重复岂不浪费性能?所以共同的放在原型上就行啦

new之前怎么做?

function Person(ID){
  var obj = {}
  obj.__proto__ = Person.原型 (这可不是一个正常工作中的写法!)
  obj.name = 'Colin'
  obj.age = 21
  return obj
}

Person.原型 = {
 sayName:function(){
   console.log(this.name)
 }
}

那有了new之后

function Person(ID) {
  this.name = 'Colin';
  this.age = 21;
}

Person.prototype.sayName = function() {
  console.log(this.name);
};

// 使用示例:
var person = new Person();
person.sayName(); // 输出:Colin

看起来棒极了!少了几行代码

  1. 帮我创建了临时变量
  2. 帮我绑定原型
  3. 帮我return
  4. 统一叫做prototype
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值