Lodash:如何使用orderBy对集合进行不区分大小写的排序?

时间:2016-06-16 00:37:32

标签: javascript lodash

我检查了this answer但是为了获得相同的结果,即获得不区分大小写的排序,我需要使用orderBy而不是sortBy,因为它提供了能力指定排序顺序

我发现实现它的唯一方法是创建一个克隆的"中间"数组映射到小写name

const users = [
  { name: 'A', age: 48 },
  { name: 'B', age: 34 },
  { name: 'b', age: 40 },
  { name: 'a', age: 36 }
];

let lowerCaseUsers = _.clone(users);

lowerCaseUsers = lowerCaseUsers.map((user) => {
  user.name = user.name.toLowerCase();
  return user;
});

const sortedUsers = _.orderBy(lowerCaseUsers, ['name'], ['desc']);

console.log(sortedUsers);

这看起来非常昂贵,而且对于多个排序和动态属性名称来说甚至会更复杂。

有更好的主意吗?

这是一个Plunker:https://plnkr.co/edit/i1ywyxjFctuNfHtPTcgG

3 个答案:

答案 0 :(得分:121)

documentation指定您可以将函数传递为" iteratee":

  

[iteratees = [_。identity]](Array [] | Function [] | Object [] | string []):迭代次数排序。

所以你可以做到



const users = [
  { name: 'A', age: 48 },
  { name: 'B', age: 34 },
  { name: 'b', age: 40 },
  { name: 'a', age: 36 }
];

const sortedUsers = _.orderBy(users, [user => user.name.toLowerCase()], ['desc']);
console.log(sortedUsers);

<script src="https://cdn.jsdelivr.net/lodash/4.13.1/lodash.min.js"></script>
&#13;
&#13;
&#13;

答案 1 :(得分:0)

您可以将Felix Kling示例与_.get函数结合使用,以按动态嵌套属性进行排序:

const _ = require('lodash');

let test = [{ a: {b:'AA'}},{a: {b:'BB'} }, {a: {b: 'bb'}}, {a:{b:'aa'}}];

let attrPath = 'a.b';

_.orderBy(test, [item => _.get(item, attrPath).toLowerCase()]);

答案 2 :(得分:0)

订购多个属性。

const users = [
  { name: 'A', age: 48 },
  { name: 'B', age: 34 },
  { name: 'b', age: 40 },
  { name: 'a', age: 36 }
];

const sortedUsers = _.orderBy(users, [user => user.name.toLowerCase(), 'age'], ['desc', 'asc']);
console.log(sortedUsers);