new 操作符原理及实现

目录

一句话介绍 new

new 的原理

实现 new


一句话介绍 new

new 运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象的实例。(来自MDN)

new 的原理
  1. 创建一个空的对象 const obj = {};
  2. 设置 obj._proto_ = Fn.prototype(obj 隐式原型 __proto__ 链接到构造函数 Fn 显式原型 prototype 上)
  3. 绑定 this 到 obj 上, 执行Fn(构造函数)
  4. 如果 Fn 返回的不是引用类型,则返回 obj
实现 new
function myNew(Fn, ...args){

    const obj = {}

    obj.__proto__ = Fn.prototype

    const res = Fn.call(obj, ...args)

    return ['object', 'function'].includes(typeof res) ? res : obj
}


// 测试代码
function Person(name, age, job) {
    this.name = name;
    this.age = age;
    this.job = job;
    this.sayName = function() {
       console.log(this.name)
    }
}

// var person = new Person('Jasmine', 31, 'Front-end developer'); 
var person = myNew(Person, 'Jasmine', 31, 'Front-end developer');

console.log(person.name) // Jasmine
person.sayName();        // Jasmine
console.log(person.__proto__ === Person.prototype);   // true

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

橘子味的冰淇淋~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值