在闭包中使用原型模式

时间:2011-07-02 20:24:09

标签: javascript oop closures prototypal-inheritance

我一直在使用Javascript中的原型和闭包模式。您可能知道,使用闭包模式时有一个performance penalty因为它为对象的每个实例重新定义了相同的函数。但是,闭包模式确实允许私有变量,这使得封装更容易。

以下是原型模式的典型示例:

function Foo(val) {
    this.val = val;
}

Foo.prototype.getVal = function() {
    return this.val;
}

var f = new Foo(42);

我在想,为什么你不能做这样的事情?

function Parent() {

}

Parent.prototype.getVal = function() {
    return this.val;
}

function foo(val) {
    function Obj {
        this.val = val;
    }

    Obj.prototype = new Parent();

    return new Obj();
}

var f = foo(42); // Note the missing 'new'

这允许在foo()函数中使用私有变量,甚至可以在foo()函数中动态设置原型。

我做了一个jsperf.com test,其中的契约表现出很大的差异,但我不知道为什么。

1 个答案:

答案 0 :(得分:2)

性能上的差异很可能是因为您正在创建两个对象而不是一个。您正在创建一个额外的对象,仅用作另一个的原型。

如果你想创建这样的很多对象,你应该创建一个原型对象并将其用作你创建的所有对象的原型。