码迷,mamicode.com
首页 > Web开发 > 详细

JS中new操作符源码实现

时间:2019-08-02 14:43:33      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:pre   对象   就是   bsp   继承构造函数   构造   prot   script   type属性   

首先我们来看一下实例化一个对象做了浏览器做了什么事情

new的四步操作:

1. 创建一个空对象

2. 设置空对象的__proto__属性继承构造函数的prototype属性,也就是继承构造函数的原型对象上的公有属性和方法

3. 调用构造函数,将构造函数中的this替换为空对象的this,继承构造函数中的属性

4. 在函数内部返回一个新对象

 源码实现

function myNew (fun) {
  return function () {
    // 创建一个新对象且将其隐式原型指向构造函数原型
    let obj = {
      __proto__ : fun.prototype
    }
    // 执行构造函数
    fun.call(obj, ...arguments)
    // 返回该对象
    return obj
  }
}

function person(name, age) {
  this.name = name
  this.age = age
}
let obj = myNew(person)(‘chen‘, 18) // {name: "chen", age: 18}

  

JS中new操作符源码实现

标签:pre   对象   就是   bsp   继承构造函数   构造   prot   script   type属性   

原文地址:https://www.cnblogs.com/jiajialove/p/11288255.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!