6

在我的视图模型中,我有一个 knockoutjs ObserableArray。在我初始化 ViewModel 之后,它就成功绑定了数据。然后,我需要做的是对集合进行排序。

$.each(vm.searchResults(), function (i, property) {
    console.log(property.Name());
});

vm.searchResults().sort(function (a, b) {
    return a.Name().toLowerCase() > b.Name().toLowerCase() ? 1 : -1;
});

$.each(vm.searchResults(), function (i, property) {
    console.log(property.Name());
});

如您所见,我将元素的名称输出到控制台以查看排序前后的顺序。排序工作得很好。问题在于 UI 更新。不知何故,用户界面没有更新。

然后,尝试使用以下代码从数组中删除一条记录,以查看 UI 是否会响应:

vm.searchResults().shift();

UI 保持不变,没有再次更新。这里会有什么问题?

编辑:

这也是一个示例案例:http: //jsfiddle.net/tugberk/KLpwP/

这里也有同样的问题。

编辑:

我解决了这个示例中显示的问题:http: //jsfiddle.net/tugberk/KLpwP/16/但我仍然不确定为什么它像我最初尝试的那样有效。

4

1 回答 1

18

当您要对它进行排序时,您正在展开可观察数组。这是导致问题的原因,因为 KO 无法跟踪数组已更改。ko.observableArray()具有sort相同签名的功能,它会通知 observable 的订阅者它已被更改。解决方案很简单:删除大括号vm.searchResults().sort=> vm.searchResults.sort。查看我的示例:http: //jsfiddle.net/RbX86/

另一种告诉 KO 数组发生变化的方法 -valueHasMutated在使用数组操作后调用方法。请查看此示例: http: //jsfiddle.net/RbX86/1/ 当您需要在数组中进行许多更改并且只想刷新一次 UI 时,这种方法非常好。

于 2012-05-07T10:28:42.623 回答