对对象数组进行排序

JavaScriptJavaScriptBeginner
立即练习

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

💡 本教程由 AI 辅助翻译自英文原版。如需查看原文,您可以 切换至英文原版

简介

在本实验中,我们将探索如何根据提供的属性和顺序对对象数组进行排序。我们将使用 Array.prototype.sort() 方法和 Array.prototype.reduce() 方法来实现这一点。本实验将让你切实了解如何在 JavaScript 中操作对象数组。


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("JavaScript")) -.-> javascript/AdvancedConceptsGroup(["Advanced Concepts"]) javascript(("JavaScript")) -.-> javascript/BasicConceptsGroup(["Basic 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 中对对象数组进行排序,你可以在 props 数组上使用 Array.prototype.sort() 方法和 Array.prototype.reduce() 方法,并使用默认值 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 中练习更多实验来提升你的技能。