js中new操作符经历了什么

背景知识

__proto__和prototype区别

  • prototype属性是一个静态属性,
  • __proto__属性是一个实例属性。
  • prototype表示类的原型对象,__proto__表示原型对象中定义的内部属性[prototype]的值。
  • 类的每一个实例都有一个__proto__属性,用于引用创建它的构造方法的prototype属性,也就是该类的原型对象,即存在如下等式:(new Array(“abc”)).proto===Array.prototype (Array(“abc”)为Array的实例)
console.log(Object,Object.prototype)
let obj = new Object
console.log(obj)
console.log(Object.prototype === obj.__proto__)

在这里插入图片描述

new操作符可分为四步

  1. 创建空对象
  2. 将空对象的原型,指向构造函数的原型
  3. 改变this指向,将空对象作为构造函数的上下文
  4. 返回对象。返回值为基础数据类型时,则忽略返回值;当返回值为引用数据类型时,则使用retuen返回的值,new就失效了

手写new

function MyNew(fun, ...args) {
    let obj = {}
    obj.__proto__ = fun.prototype
    let res = fun.apply(obj, args)
    return res instanceof Object ? res : obj
}

function test(age, name) {
    this.age = age
    this.name = name
    return 111
}
console.log(MyNew(test, 18, '李四'))

在这里插入图片描述
当构造函数返回引用数据类型时

function MyNew(fun, ...args) {
    let obj = {}
    obj.__proto__ = fun.prototype
    let res = fun.apply(obj, args)
    return res instanceof Object ? res : obj
}

function test(age, name) {
    this.age = age
    this.name = name
    return [1,2,3]
}
console.log(MyNew(test, 18, '李四'))

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值