js中的prototype和constructor

本文解析了JavaScript中构造函数与原型的关系,重点介绍了如何正确设置构造函数的prototype属性以避免潜在问题。

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

在这之前先说明几个问题:

prototype是JavaScript中所有对象都具有的属性,
constructor是用new创建函数的才有的属性。

当使用new来创建一个函数时,JavaScript会自动创建一个prototype属性,并且将prototype.constructor属性指向该函数本身。

见下面的例子(在firebugs下完成):
>>> Object.prototype. constructor === Object
true
>>> function Hero() {this.name = "Hero"}
>>> Hero.prototype.constructor == Hero
true
>>> var h1 = new Hero()
>>> h1.constructor //没有更改prototype的情况下,h1.constructor是正确的
Hero()
>>> Hero.prototype = {} //将Hero.prototype制空
Object
>>> var h2 = new Hero()
>>> h2.constructor  //h2.constructor是错误的
Object()
>>> function Hero2() {this.name = "Hero2"}
>>> Hero.prototype = new Hero2 //将Hero.prototype制为Hero2
Object
>>> var h3 = new Hero()
>>> h3.constructor //h3.constructor是错误的
Hero2()
>>> Hero.prototype.constructor = Hero //将Hero.prototype.constructor设置回去
Hero()
>>> var h4 = new Hero()
>>> h4.constructor //恢复正常
Hero()

 

所以在自己设置函数的prototype时,一定要同时更改函数的constructor属性,要不然会出现一些莫名其妙的问题!

JavaScriptprototypeconstructorJavaScript中的两个概念,用于实现对象的继承构造。 prototype(原型)是JavaScript中每个对象都有的一个属性,它指向该对象的原型(即父对象)。每个函数都有一个prototype属性,它是一个指向该函数的原型对象的指针。通过修改prototype,可以给该函数的实例对象添加新的属性方法。这样,函数的实例对象就可以共享这些属性方法,从而实现了对象的继承。 constructor(构造函数)是一个指向创建该对象的函数的指针。每个对象都有一个constructor属性,它指向该对象的构造函数。通过Constructor属性,我们可以追踪一个对象是由哪个构造函数创建的,以便在需要时通过构造函数进行实例化。 通过prototypeconstructor的结合使用,可以在JavaScript中实现对象的继承构造。具体的步骤如下: 1. 创建一个构造函数,并定义其原型对象中的属性方法。 2. 使用new关键字实例化一个对象。 3. 通过对象的constructor属性,可以确定对象是由哪个构造函数创建的。 4. 进一步修改构造函数的原型对象,可以为所有实例对象添加新的属性方法。 JavaScript中的原型继承构造函数是基于原型链的概念。通过在对象之间共享属性方法,可以实现更高效的内存使用代码复用。prototypeconstructor提供了一种灵活而强大的方式来创建继承对象,它们是JavaScript中非常重要的概念。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值