Lodash: วิธีการเรียงลำดับแบบไม่คำนึงถึงตัวพิมพ์เล็กและใหญ่ในคอลเลกชันโดยใช้ orderBy?


90

ฉันจะตรวจสอบคำตอบนี้แต่เพื่อให้บรรลุผลเดียวกันนั่นคือการได้รับการเรียงลำดับกรณีตายฉันต้องการที่จะใช้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

คำตอบ:


190

เอกสารระบุว่าคุณสามารถส่งผ่านฟังก์ชั่นเป็น "iteratee" A:

[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>


2
สิ่งนี้อาจล้มเหลวในเบราว์เซอร์รุ่นเก่า
นึ่ง

16
หากคุณหมายความว่าสิ่งนี้จะทำให้เกิดข้อผิดพลาดทางไวยากรณ์ในเบราว์เซอร์ที่ไม่รองรับ ES6 ใช่แน่นอน ฉันจะปล่อยให้การแปลงฟังก์ชันลูกศรเป็นฟังก์ชัน "ปกติ" (และconstถึงvar) เป็นการออกกำลังกายสำหรับผู้อ่าน
Felix Kling

@TheCaptan: ไม่มีเหตุผลที่ไม่ควร
Felix Kling

2
ฉันกำลังพยายามถามคำถามต่อไปนี้ของ @ TheCaptan แต่ได้รับข้อผิดพลาดของคอมไพเลอร์:const sortedUsers = _.orderBy(users, [user => user[propToSort].toLowerCase()], ['desc']);
im1dermike

1
@ im1dermike: คุณอาจต้องการใช้.toString()ก่อนที่จะเรียกใช้ตัวพิมพ์เล็กที่นั่นนอกจากนี้หากคุณต้องการใช้property.somethingสำหรับ propToSort และสิ่งที่คล้ายกันคุณสามารถใช้ได้_.get(user, propToSort)(อาจจะช่วยคนอื่นได้)
Soniku

10

การเรียงลำดับตามคุณสมบัติหลายรายการ:

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

const nameSorter = user => user.name.toLowerCase()
const ageSorter = 'age'

const sortedUsers = _.orderBy(users, [nameSorter, ageSorter], ['desc', 'asc'])

2

คุณสามารถรวมตัวอย่าง 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()]);
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.