KnockoutJs计算的数组未正确计算

时间:2012-10-15 06:51:43

标签: javascript mvvm knockout.js

代码如下:EmployeeModel是viewModel,问题是当我在employees(obs数组)中更改项目的属性 - deletedFlag时,deletedItems不会更新。

我该如何解决这个问题?

  function Employee(data) {
    this.employeid = ko.observable(data.employeid);
    this.name = ko.observable(data.name);
    this.isactive = ko.observable(data.isactive);
    this.deletedFlag = ko.observable(false);
}

var EmployeeModel = function () {
    var self = this;
    self.employees = ko.observableArray([]);

    self.deletedItems = ko.computed(function () {
        return ko.utils.arrayFilter(self.employees(), function (item) {
            return item.deletedFlag == true;
        });
    }, this);
}

编辑:以下代码标记数组中的一个项目以进行删除

self.removeEmployee = function (employee) {
        employee.deletedFlag(true);
    };

1 个答案:

答案 0 :(得分:1)

属性deletedFlag是一个可观察的属性,因此您需要通过将其作为函数调用来检索其当前值(您无法将其直接与任何值进行比较):

self.deletedItems = ko.computed(function () {
    return ko.utils.arrayFilter(self.employees(), function (item) {
        return item.deletedFlag() == true; // <===
    });
}, this);