JavaScript深入理解-new关键字创建对象底层原理

2019-03-01  本文已影响0人  朴小壹

JavaScript中 new 操作符可以通过构造函数创建对象,但是其底层原理大多人都不太清楚,下面我们来详解一下 new 操作符的底层原理。(PS:JavaScript有8种内置的构造函数:Object、Array、Function、Date、RegExp、Number、String、Set、Map

首先看一下这句代码:

var obj = {};
var arr = [];

// 其实这只是JavaScript中创建对象的语法糖,本质上为

var obj = new Object();
var arr = new Array();

下面详解 new Object() 底层是如何运行的,大致分为三步,

  1. 创建一个空对象 {};
  2. 将空对象的 proto 原型对象 指向 Object.prototype;
  3. 将Object构造函数的this指向当前空对象
  var obj;

  创建空对象:{};

  {}.__proto__ = Object.prototype;

  Object.call({});

  obj = {};

示例:

  function People() {
    this.name = 'phuhoang';
  }
  var me = new People();        // { name: 'phuhoang'}

  // 其执行过程拆分为

  0. var me;
  1. 内存开辟空间创建空对象 {}                // {}
  2. {}.__proto__ = People.prototype      // { __proto__: People.prototype }
  3. People.call({})                      // { name: 'phuhoang', __proto__: People.prototype }
  4. me = { name: 'phuhoang', __proto__: People.prototype }  
上一篇下一篇

猜你喜欢

热点阅读