js 对象实例化计数

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?

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

阅读 2.4k
2 个回答
  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)
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题