JavaScript原型的好处

时间:2010-08-11 20:19:59

标签: javascript prototype

我一直在想JavaScript的原型性质及其好处,并且归结为以下列表:

1)继承

cat.prototype = animal

2)内存效率

a.prototype.b = function() {}

var a1 = new a();
var a2 = new a();

然后a1.b和a2.b基本上是同一个对象,其中:

var a = function() {
             this.b = function() {}; 
        }

var a1 = new a();
var a2 = new a();

a1.b和a2.b将是不同的函数对象并占用更多内存。

3)将方法/字段添加到已创建的多个“野外”对象中。

var a = function() {}

var a1 = new a();
var a2 = new a();

a.prototype.b = function() {}

a1.b();
a2.b();

所以问题是,这些是正确的吗?

......还有其他任何我错过的好处吗?

干杯!

2 个答案:

答案 0 :(得分:6)

这些都是正确的。

当然,也有“缺点”:

没有关闭

function a() {
    var ival = 0;
    this.start = function(){ ival = setInterval(function(){ }, 300); }
    this.finish = function(){ clearTimeout(ival); }
}

比较:

function a() {
    this.ival = 0;
}
a.prototype.start = function(){ this.ival = setInterval(function(){ }, 300); }
a.prototype.finish = function(){ clearTimeout(this.ival); }

答案 1 :(得分:2)