实现JavaScript中的new运算符

本文深入探讨了JavaScript中如何通过构造器创建对象实例的过程。详细解释了构造器与函数之间的关系,以及如何使用new操作符来实例化对象。通过具体代码示例展示了构造器的工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在JavaScript中没有类的概念,常常通过new来克隆一个对象,例如new girlFriend(); 这里的girlFriend不是类,而是一个函数构造器,当使用new运算符来调用函数时,此时的函数就是一个构造器,置于new底层怎么实现的,就上代码吧。

var  newFactory = function(){

 var obj = {}; // javasript中没有类所有的对象都是通过克隆实现的,Object.prototype就是JavaScript中的根对象

 var Constructor = [].shift.call(arguments);//由于arguments是一个类数组对象,需要进行类型转换再通过shift来获取需要构造器

obj._proto_ = Constructor.prototype;//指向正确的原型

 var ret = Constructor.apply(obj, arguments);//为obj设置属性

return typeof ret === 'object' ? ret : obj;//返回一个对象 

}

这两行代码产生同样的效果

var gril = newFactory(people, "Alice");

var girl = new people("Alice");


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值