对象的淘汰赛arraygetdistinctvalues(knockout arraygetdist

2019-07-18 11:24发布

我想用ko.utils.arrayGetDistinctValues像这样小提琴不止一个属性在一个数组,所以我的阵图,只是两个属性我想的数组

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);

我在这里修改拨弄

谁能告诉我如何做到这一点?

Answer 1:

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/



Answer 2:

作为更新麦可思的回答,这里使用的东西更近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})


文章来源: knockout arraygetdistinctvalues of objects
标签: knockout.js