javascript - 排序 "day" "week" "month"和 "year"

标签 javascript arrays sorting object

我有一个来自 API 的对象数组

[
{path: 'image', location: 'LOCATION_1', time: 'day'}
1: {path: 'image', location: 'LOCATION_2', time: 'week'}
2: {path: 'image', location: 'LOCATION_1', time: 'year'}
3: {path: 'image', location: 'LOCATION_1', time: 'week'}
4: {path: 'image', location: 'LOCATION_1', time: 'month'}
5: {path: 'image', location: 'LOCATION_2', time: 'day'}
6: {path: 'image', location: 'LOCATION_2', time: 'month'}
7: {path: 'image', location: 'LOCATION_2', time: 'year'}
]

我想根据时间对它们进行排序,但是当我这样做时, 它就像

day
month
week
year

有什么办法可以让它像:

day
week
month
year

我正在 JavaScript 中使用函数组件。

最佳答案

在排序函数中,您正在与字符串进行比较,这就是您获得按字母顺序排序的列表的原因。如果您想要自定义顺序,您可以创建一个 map 来遵循该顺序。

const data = [
  {path: 'image', location: 'LOCATION_1', time: 'day'},
  {path: 'image', location: 'LOCATION_2', time: 'week'},
  {path: 'image', location: 'LOCATION_1', time: 'year'},
  {path: 'image', location: 'LOCATION_1', time: 'week'},
  {path: 'image', location: 'LOCATION_1', time: 'month'},
  {path: 'image', location: 'LOCATION_2', time: 'day'},
  {path: 'image', location: 'LOCATION_2', time: 'month'},
  {path: 'image', location: 'LOCATION_2', time: 'year'},
];

const timeMap = {
  day: 0,
  week: 1,
  month: 2,
  year: 3,
}

data.sort((a, b) => {
  return timeMap[a.time] - timeMap[b.time];
});

console.log(data);

关于javascript - 排序 "day" "week" "month"和 "year",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70950740/

相关文章:

c++ - 查找 double * 数组的大小 C++

Java - 对结果进行排序

Javascript 复选框选择顺序

java - 将数组的数组存储在它自己的类中?

javascript - 在 angularjs 应用程序中使用 requirejs 和 AMD 有什么好处?

javascript - Array 对象与 Object 是否不同(认为两者的 typeof 返回相同的值)?

c# - 在C#中产生两个列表项的集合差异

javascript - 在页面加载时按字母顺序对 html 表进行排序

javascript - 将 Chrome 中 keydown 上的 <div> 标记替换为 <br> 以实现 HTML contenteditable

javascript - Sequelize 不对子嵌套查询排序