Lodash orderBy 基于 属性 child 计数

Lodash orderBy based on property child count

我想统计 objects 的 属性 和 orderBy 考虑计数结果。

 var users = [
            { 'user': 'fred',   'age': 48 },
            { 'user': 'barney', 'age': 34 }
        ];

// Sort by `user` in ascending order and by `age` in descending order.
        _.orderBy(users, ['user', 'age'], ['asc', 'desc']);

根据文档,这项工作有效,但我想要的是像这样的东西:

var users = [
            { 'user': 'barney', 'age': 34 ,Likes: [{objAA},{objBA}]},
            { 'user': 'fred',   'age': 48 ,Likes: [{objBA},{objBB},{objBC}]},
            { 'user': 'barney', 'age': 34 ,Likes: [{objDA},{objDA}]},
            { 'user': 'barney', 'age': 34 ,Likes: [{objCA}]}
        ];

orderBy 点赞数

var users = [
            { 'user': 'fred',   'age': 48 ,Likes: [{objBA},{objBB},{objBC}]},
            { 'user': 'barney', 'age': 34 ,Likes: [{objAA},{objBA}]},
            { 'user': 'barney', 'age': 34 ,Likes: [{objDA},{objDA}]},
            { 'user': 'barney', 'age': 34 ,Likes: [{objCA}]}
        ];

仅使用 loadh 是否可行?

我需要的是

_.orderBy(users, ['user.Likes.length'], ['desc']);
_.orderBy(users, ['user.Likes'], ['desc']);

但是上面的代码没有运行但是没有错误

我想使用 orderBy 函数来组合顺序,例如

_.orderBy(users, ['user.Likes','user', 'age'], ['desc','asc', 'desc']);

您可以将函数作为迭代器传递:

_.orderBy(users, function(user) { return user.Likes.length; }, ['desc']);

你可以像这样使用函数迭代器

 _.orderBy(users, ['user', function (o) {
    return o.likes.length;
 }], ["asc", "asc"])

这是一个例子

var users = [{
  'user': 'fred',
  'age': 48,
  'likes': [{c:1}, {c:2}, {c:3}]
}, {
  'user': 'barney',
  'age': 34,
  'likes': [{c:1}, {c:2}, {c:3}, {c:3}]
}, {
  'user': 'ammar',
  'age': 25,
  'likes': [{c:1}, {c:2}, {c:3}, {c:3}, {c:1}, {c:2}, {c:3}]
}, {
  'user': 'boston',
  'age': 34,
  'likes': [{c:1}, {c:3}]
}, {
  'user': 'obama',
  'age': 34,
  'likes': [{c:1}]
}, {
  'user': 'barney',
  'age': 34,
  'likes': [{c:1}, {c:2}, {c:3}]
}];


document.write(JSON.stringify(_.orderBy(users, ['user', function (o) {
  return o.likes.length;
}], ["asc", "asc"]), null, 4))
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.6.1/lodash.min.js"></script>