new 一个对象发生了什么

2021-01-15  本文已影响0人  FAKEEER

使用 new 操作符实例化 Person 的操作等于使用 new 调用其构造函数。唯一可感知的不同之处就是, JavaScript 解释器知道使new和类意味着应该使用 constructor 函数进行实例化。使用 new 调用类的构造函数会执行如下操作。
(1) 在内存中创建一个新对象。
(2) 这个新对象内部的[[Prototype]]指针被赋值为构造函数的 prototype 属性。
(3) 构造函数内部的 this 被赋值为这个新对象(即 this 指向新对象)。
(4) 执行构造函数内部的代码(给新对象添加属性)。
(5) 如果构造函数返回非空对象,则返回该对象;否则,返回刚创建的新对象。
摘自 《JavaScript高级程序设计(第4版)》

class Animal {}
class Person {
  constructor() {
  console.log('person ctor');
  }
}
class Vegetable {
  constructor() {
  this.color = 'orange';
  }
}
let a = new Animal();
let p = new Person(); // person ctor
let v = new Vegetable();
console.log(v.color); // orange
上一篇下一篇

猜你喜欢

热点阅读