Упорядочить массив объектов

JavaScriptJavaScriptBeginner
Практиковаться сейчас

This tutorial is from open-source community. Access the source code

💡 Этот учебник переведен с английского с помощью ИИ. Чтобы просмотреть оригинал, вы можете перейти на английский оригинал

Введение

В этом лабе мы изучим, как сортировать массив объектов в соответствии с предоставленными свойствами и порядком. Для этого мы будем использовать метод Array.prototype.sort() и метод Array.prototype.reduce(). Лабе даст практическое понимание того, как манипулировать массивами объектов в JavaScript.


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("JavaScript")) -.-> javascript/BasicConceptsGroup(["Basic Concepts"]) javascript(("JavaScript")) -.-> javascript/AdvancedConceptsGroup(["Advanced Concepts"]) javascript/BasicConceptsGroup -.-> javascript/variables("Variables") javascript/BasicConceptsGroup -.-> javascript/data_types("Data Types") javascript/BasicConceptsGroup -.-> javascript/arith_ops("Arithmetic Operators") javascript/BasicConceptsGroup -.-> javascript/comp_ops("Comparison Operators") javascript/BasicConceptsGroup -.-> javascript/cond_stmts("Conditional Statements") javascript/BasicConceptsGroup -.-> javascript/array_methods("Array Methods") javascript/AdvancedConceptsGroup -.-> javascript/higher_funcs("Higher-Order Functions") javascript/AdvancedConceptsGroup -.-> javascript/destr_assign("Destructuring Assignment") javascript/AdvancedConceptsGroup -.-> javascript/spread_rest("Spread and Rest Operators") subgraph Lab Skills javascript/variables -.-> lab-28535{{"Упорядочить массив объектов"}} javascript/data_types -.-> lab-28535{{"Упорядочить массив объектов"}} javascript/arith_ops -.-> lab-28535{{"Упорядочить массив объектов"}} javascript/comp_ops -.-> lab-28535{{"Упорядочить массив объектов"}} javascript/cond_stmts -.-> lab-28535{{"Упорядочить массив объектов"}} javascript/array_methods -.-> lab-28535{{"Упорядочить массив объектов"}} javascript/higher_funcs -.-> lab-28535{{"Упорядочить массив объектов"}} javascript/destr_assign -.-> lab-28535{{"Упорядочить массив объектов"}} javascript/spread_rest -.-> lab-28535{{"Упорядочить массив объектов"}} end

Как упорядочить массив объектов в JavaScript

Для упорядочивания массива объектов в JavaScript можно использовать метод Array.prototype.sort() и метод Array.prototype.reduce() на массиве props со значением по умолчанию 0.

Вот пример функции orderBy, которая сортирует массив объектов в соответствии с указанными свойствами и порядками:

const orderBy = (arr, props, orders = ["asc"]) =>
  [...arr].sort((a, b) =>
    props.reduce((acc, prop, i) => {
      if (acc === 0) {
        const [p1, p2] =
          orders[i] === "desc" ? [b[prop], a[prop]] : [a[prop], b[prop]];
        acc = p1 > p2 ? 1 : p1 < p2 ? -1 : 0;
      }
      return acc;
    }, 0)
  );

Для использования этой функции передайте массив объектов, массив свойств для сортировки и необязательный массив порядков. Если массив orders не передан, функция по умолчанию будет сортировать по 'asc'.

Вот несколько примеров использования функции orderBy:

const users = [
  { name: "fred", age: 48 },
  { name: "barney", age: 36 },
  { name: "fred", age: 40 }
];

// сортировать по имени по возрастанию и по возрасту по убыванию
orderBy(users, ["name", "age"], ["asc", "desc"]);
// Вывод: [{name: 'barney', age: 36}, {name: 'fred', age: 48}, {name: 'fred', age: 40}]

// сортировать по имени по возрастанию и по возрасту по возрастанию (стандартный порядок)
orderBy(users, ["name", "age"]);
// Вывод: [{name: 'barney', age: 36}, {name: 'fred', age: 40}, {name: 'fred', age: 48}]

Резюме

Поздравляем! Вы завершили лабу "Упорядочить массив объектов". Вы можете практиковаться в более лабах в LabEx, чтобы улучшить свои навыки.