javascript - js 对象实例化计数
高洛峰
高洛峰 2017-04-11 12:06:42
[JavaScript讨论组]
function Person() {
    Person.num++
}

Person.num = 0

for (var i = 0; i < 6; i++) {
    var gjy = new Person()
}

console.log(Person.num)

如上代码可以记录Person对象被实例了几次,但是如果进行如下修改为什么就不行了?

function Person() {
    this.num++
}

还有如果输出

console.log(gjy.num)

为什么不能得到6?

是否可以利用原型链来实现这个功能 ?

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(2)
ringa_lee
  1. 改为this,并实例化Person后,this指向gjy,实际上执行的是gjy.num++

  2. Person.num = 0中的num属性不会被gjy继承,因此gjy.num为undefined,gjy.num++结果为NaN

  3. 下面代码可以达到你想要的效果

function Person() {
    Person.prototype.num++
}

Person.prototype.num = 0

for (var i = 0; i < 6; i++) {
    var gjy = new Person()
}

console.log(gjy.num)
阿神

因为Person.num是静态属性,类似于声明了一个全局变量num,所以可以统计实例次数。
但是如果写成'this.num'则代表的是实例属性,因为在将要实例的这个对象上没有num属性则得到undefined,undefined++然后输出的是NaN。

可以通过原型来实现,但是其中操作原型会很危险,不建议。

function Person() {
    Person.prototype.num++;
}
Person.prototype.num = 0;


for (var i = 0; i < 6; i++) {
    console.log(i);
    var gjy = new Person()
}

console.log(gjy.num)
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号