new操作符具体做了什么

文章通过一个代码示例解释了如何手动创建并链接一个对象到构造函数的原型,同时调整构造函数内部的this指向,并根据构造函数的返回类型决定返回新创建的对象还是构造函数的结果。这一过程涉及到JavaScript中对象的创建、原型链的设置以及this的使用。
摘要由CSDN通过智能技术生成

1.先创建一个空对象
2.将空对象和构造函数通过原型链接起来
3.将构造函数的this指向空对象
4.根据构造函数返回的类型判断,如果是值类型,则返回的是一个对象,如果是引用数据类型,则返回这个引用数据类型

代码演示

function fun(age,name){
    this.age=age
    this.name=name
}
function created(fun,...args){
//1.先创建一个空对象
let obj={}
//2.将空对象和构造函数通过原型链接起来
Object.setPrototypeOf(obj,fun.prototype) //这个方法是为对象设置原型链
//3.将构造函数的this指向空对象
let result=fun.apply(obj,args)
//4.根据构造函数返回的类型判断,如果是值类型,则返回的是一个对象,如果是引用数据类型,则返回这个引用数据类型
return result instanceof Object ? result : obj
}
console.log(created(fun,18,'张三'))

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值