0

我知道将方法直接分配给类的原型是一种很好的做法,这样每次调用函数时就不会重新定义它们。

var A = function () {
    this.prop = "A property";
}
A.prototype.method = function () {
    return "A method";
}

假设我想在构造函数中调用以这种方式定义的方法。这可能吗?

var A = function (options) {
    initialize(options); // initialize is undefined.
}
A.prototype.initialize = function (options) {
    // do something with options.
}

在构造函数中创建存根方法不起作用,因为它被调用而不是原型的函数版本。我能够让它工作的唯一方法是通过括号语法引用该函数,this["initialize"]()这似乎很不雅。

var A = function (options) {
    this["initialize"](options); // function isn't defined yet but will be soon!
}
A.prototype.initialize = function (options) {
    // do something with options.
}

这看起来很笨拙,可能不是调用此函数的最佳方式。还有其他方法还是我错过了什么?

4

1 回答 1

6

您的最后一种方式是正确的,但您不需要引号。

var A = function (options) {
    this.initialize(options); 
};
A.prototype.initialize = function (options) {
    // do something with options.
};

假设A作为构造函数被调用,this是对正在构造的新对象的引用,并且它的原型链已经建立,因此它已经可以访问该initialize方法。

当然,initialize不需要原型。如果不打算多次调用它,那么将其定义为独立函数可能更有意义。

var A = function (options) {
    initialize(this, options); 
};
function initialize (obj, options) {
    // do something with options.
};

或者您可以将初始化代码直接放在构造函数中。

于 2012-12-10T01:41:36.803 回答