orderBy
複数の基準と並び順に従って、オブジェクト配列をソートした新しい配列を返します。
typescript
const sorted = orderBy(arr, criteria, orders);参照
orderBy(arr, criteria, orders)
オブジェクト配列を複数の条件で複合ソートしたい場合は orderBy を使用してください。各条件ごとに昇順または降順を指定でき、前の条件で同じ値の場合は次の条件でソートします。
typescript
import { orderBy } from 'es-toolkit/array';
// 複数の基準でユーザー配列をソートします。
const users = [
{ user: 'fred', age: 48 },
{ user: 'barney', age: 34 },
{ user: 'fred', age: 40 },
{ user: 'barney', age: 36 },
];
orderBy(users, [obj => obj.user, 'age'], ['asc', 'desc']);
// Returns:
// [
// { user: 'barney', age: 36 },
// { user: 'barney', age: 34 },
// { user: 'fred', age: 48 },
// { user: 'fred', age: 40 }
// ]
// プロパティ名と関数を混ぜて使用できます。
const products = [
{ name: 'Apple', category: 'fruit', price: 1.5 },
{ name: 'Banana', category: 'fruit', price: 0.8 },
{ name: 'Broccoli', category: 'vegetable', price: 2.0 },
];
orderBy(products, ['category', product => product.name.length], ['asc', 'desc']);
// Returns: categoryでまずソートし、同じcategory内では名前の長さの降順でソート並び順の数が条件より少ない場合、最後の並び順を繰り返し使用します。
typescript
import { orderBy } from 'es-toolkit/array';
const data = [
{ a: 1, b: 1, c: 1 },
{ a: 1, b: 2, c: 2 },
{ a: 2, b: 1, c: 1 },
];
orderBy(data, ['a', 'b', 'c'], ['asc', 'desc']);
// 'a'は昇順、'b'と'c'は降順でソートされます。パラメータ
arr(T[]): ソートするオブジェクト配列です。criteria(Array<((item: T) => unknown) | keyof T>): ソートする基準です。オブジェクトのプロパティ名または値を返す関数を使用できます。orders(Array<'asc' | 'desc'>): 各基準に対する並び順の配列です。'asc'は昇順、'desc'は降順を意味します。
戻り値
(T[]): 指定された基準と並び順に従ってソートされた新しい配列です。

