使用KnockoutJS计算属性的原型

时间:2013-01-02 10:34:43

标签: knockout.js

是否建议在原型对象上创建计算属性?

这是我在下面尝试过的,但是firstName绑定将函数作为字符串返回而不是执行它(http://jsfiddle.net/W37Yh)。

var HomeViewModel = function(config, $, undefined) {

    if (!this instanceof HomeViewModel) {
        return new HomeViewModel(config, $, undefined);
    }

    this.firstName = ko.observable(config.firstName);
    this.lastName = ko.observable(config.lastName);
};

HomeViewModel.prototype.fullName = function() {
    return ko.computed(function() {
        return this.firstName() + " " + this.lastName();
    }, this);
};

var model = new HomeViewModel({
    firstName: "John",
    lastName: "Smith"
}, jQuery);

ko.applyBindings(model);​

1 个答案:

答案 0 :(得分:15)

this不是Actual viewmodel,因为尚未创建实例。你可以做到

ViewModel = function() {
   this.fullName = ko.computed(this.getFullName, this);
};

ViewModel.prototype = {
   getFullName: function() {
      return this.firstName() + " " + this.lastName();
   }
};