这里有淘汰新手。我试过使用ko.utils.arrayFilter,但是当我使用它时似乎没有更新。我使用的是与arrayForEach相同的方法,所以我不确定这里有什么问题。如何在使用arrayFilter时更新列表?
JS:
function entry(name, category) {
this.name = ko.observable(name);
this.category = ko.observable(category);
}
function entriesModel() {
this.entries = ko.observableArray([]);
this.filter = function () {
ko.utils.arrayFilter(this.entries(), function (item) {
return item.category == 'SciFi';
});
};
this.sort = function () {
this.entries.sort(function (a, b) {
return a.category < b.category ? -1 : 1;
});
};
}
$(document).ready(function () {
$.getJSON("entries.php", function (data) {
entries(data);
});
ko.applyBindings(entriesModel());
});
HTML:
<ul data-bind="foreach: entries">
<li>
<p data-bind="text: name"></p>
<p data-bind="text: category"></p>
</li>
<button data-bind="click: filter">Filter</button>
<button data-bind="click: sort">Sort</button>
JSON:
[{"id":"1","name":"Iron Man","category":"SciFi"},{"id":"2","name":"Terminator","category":"SciFi"},{"id":"3","name":"The Pianist","category":"Drama"},{"id":"4","name":"The Hangover","category":"Comedy"}]
答案 0 :(得分:0)
ko.utils.arrayFilter
不会过滤数组。它返回一个带有过滤项的新数组,并保留原始数组。
如何使用ko.utils.arrayFilter
的示例如下:http://www.knockmeout.net/2011/04/utility-functions-in-knockoutjs.html
答案 1 :(得分:0)
不确定这是否正是您想要的,但您的过滤器功能不会执行就地过滤器,因此您需要使用新过滤的数组重新分配observableArray。如
this.filter = function () {
this.entries(ko.utils.arrayFilter(this.entries(), function (item) {
return item.category == 'SciFi';
}));
};
见这里:http://jsfiddle.net/aKfUc/1/
如果您不想永久更改数组,可能需要使用ko.computed observable:
http://knockoutjs.com/documentation/computedObservables.html
答案 2 :(得分:0)
data-bind="value: currentFilter, valueUpdate: 'afterkeydown'"
将解决您的问题