按自定义顺序对对象数组进行排序

JavaScriptJavaScriptBeginner
立即练习

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

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

简介

在本实验中,我们将探索如何根据给定的属性和自定义顺序数组对对象数组进行排序。我们将结合使用 Array.prototype.reduce()Array.prototype.sort() 来创建一个新数组,该数组根据 order 数组中提供的顺序进行排序。本实验是学习如何在 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/spread_rest("Spread and Rest Operators") subgraph Lab Skills javascript/variables -.-> lab-28534{{"按自定义顺序对对象数组进行排序"}} javascript/data_types -.-> lab-28534{{"按自定义顺序对对象数组进行排序"}} javascript/arith_ops -.-> lab-28534{{"按自定义顺序对对象数组进行排序"}} javascript/comp_ops -.-> lab-28534{{"按自定义顺序对对象数组进行排序"}} javascript/cond_stmts -.-> lab-28534{{"按自定义顺序对对象数组进行排序"}} javascript/array_methods -.-> lab-28534{{"按自定义顺序对对象数组进行排序"}} javascript/higher_funcs -.-> lab-28534{{"按自定义顺序对对象数组进行排序"}} javascript/spread_rest -.-> lab-28534{{"按自定义顺序对对象数组进行排序"}} end

如何根据属性顺序对对象数组进行排序

要根据属性顺序对对象数组进行排序,请执行以下步骤:

  1. 打开终端/SSH 并输入 node 开始练习编码。
  2. 使用 Array.prototype.reduce()order 数组创建一个对象,将值作为键,其原始索引作为值。
  3. 使用 Array.prototype.sort() 对给定数组进行排序,跳过 prop 为空或不在 order 数组中的元素。

以下是一个根据属性顺序对对象数组进行排序的示例代码片段:

const orderWith = (arr, prop, order) => {
  const orderValues = order.reduce((acc, v, i) => {
    acc[v] = i;
    return acc;
  }, {});
  return [...arr].sort((a, b) => {
    if (orderValues[a[prop]] === undefined) return 1;
    if (orderValues[b[prop]] === undefined) return -1;
    return orderValues[a[prop]] - orderValues[b[prop]];
  });
};

你可以使用 orderWith 函数根据属性顺序对对象数组进行排序。例如:

const users = [
  { name: "fred", language: "Javascript" },
  { name: "barney", language: "TypeScript" },
  { name: "frannie", language: "Javascript" },
  { name: "anna", language: "Java" },
  { name: "jimmy" },
  { name: "nicky", language: "Python" }
];
orderWith(users, "language", ["Javascript", "TypeScript", "Java"]);
/*
[
  { name: 'fred', language: 'Javascript' },
  { name: 'frannie', language: 'Javascript' },
  { name: 'barney', language: 'TypeScript' },
  { name: 'anna', language: 'Java' },
  { name: 'jimmy' },
  { name: 'nicky', language: 'Python' }
]
*/

总结

恭喜你!你已经完成了“根据属性顺序对对象数组进行排序”实验。你可以在 LabEx 中练习更多实验来提升你的技能。