linq.js在多个字段上使用group by

时间:2015-01-27 23:56:04

标签: javascript json linq.js

我目前有一系列对象,例如

[{Test: "123", Two: "234"}, {Test: "123", Two: "234"}, {Test: "123", Two: "222"}]

使用linq.js我如何能够运行组并返回一个列表,该列表返回重复(test,two)值的计数。我希望我的输出类似于:

[{Key: {Test: "123", Two: "234"}, Value:2}, {Key: {Test: "123", Two: "222"}, Value:1}  ]

我在想Linq.js中的GroupBy方法可能会有所帮助,但我不知道如何使用它。

1 个答案:

答案 0 :(得分:0)

您需要使用包含比较选择器的GroupBy()重载。您的密钥是对象,但您需要提供一种比较它们的方法。将项目投射到可以比较的东西(例如,一串键)。

var data = [
    { Test: "123", Two: "234" },
    { Test: "123", Two: "234" },
    { Test: "123", Two: "222" }
];
var query = Enumerable.From(data)
    // GroupBy (keySelector, elementSelector, resultSelector, compareSelector)
    .GroupBy(
        null, // (identity)
        null, // (identity)
        "{ Key: $, Value: $$.Count() }",
        "'' + $.Test + '-' + $.Two"
    )
    .ToArray();