4

配列内の複数のプロパティでこのフィドルko.utils.arrayGetDistinctValuesのように使用したいので、配列を必要な2つのプロパティだけの配列にマップします

viewModel.justCategories = ko.dependentObservable(function() {
    var categories = ko.utils.arrayMap(this.items(), function(item) {
        return { catid : item.catid(), category : item.category() };
    });
    return categories.sort();
}, viewModel);

次に使用しようとしましarrayGetDistinctValuesたが、オブジェクトでは機能しないようです。

viewModel.uniqueCategories = ko.dependentObservable(function() {
    return ko.utils.arrayGetDistinctValues(viewModel.justCategories()).sort();
}, viewModel);

ここで私の修正されたフィドル

誰かがこれを行う方法を教えてもらえますか?

4

2 に答える 2

10

arrayGetDistinctValuesプリミティブ値でのみ機能します。オブジェクトの場合は、別のアプローチが必要になります。これが機能するバージョンです。

viewModel.uniqueCategories = ko.dependentObservable(function() {
    var seen = [];
    return viewModel.justCategories().filter(function(n) {
        return seen.indexOf(n.catid) == -1 && seen.push(n.catid);
    });
});

http://jsfiddle.net/mbest/dDA4M/2/

于 2013-12-16T21:34:48.637 に答える
2

Michael Best の回答の更新として、より最近の KnockoutJS v3 コード規則を使用したものを次に示します (たとえば、dependentObservable = 計算され、arrayFilter メソッドを使用):

var uniqueSizes = ko.computed({read: function() {
    var seen = [];
    return ko.utils.arrayFilter(viewModel.collection.vendorGearFilters(), function(f) {
        return seen.indexOf(f['size_abbr']()) == -1 && seen.push(f['size_abbr']());
    });
}, deferEvaluation: true})
于 2015-06-08T15:40:25.967 に答える