首页 > 文章列表 > 如何高效地根据时间戳从大到小排序列表中的前五条数据?

如何高效地根据时间戳从大到小排序列表中的前五条数据?

128 2025-03-17

如何高效地根据时间戳从大到小排序列表中的前五条数据?

从大到小排序列表中前五条数据的时间戳

挑战: 如何高效地根据时间戳,从大到小排序列表中的前五条数据?

解决方案:

原始代码的错误在于它在每次迭代中都进行排序,导致效率低下且结果不正确。 正确的做法是先提取所有时间戳,再进行排序,最后取前五名。

改进后的代码:

function sortArr() {
  const timestamps = [];
  $(".i-list li").each(function() {
    const timestamp = Date.parse(new Date($(this).find(".time").text().replace(/-/g, "/")));
    timestamps.push(timestamp);
  });

  timestamps.sort((a, b) => b - a); // 从大到小排序

  const topFiveTimestamps = timestamps.slice(0, 5); // 获取前五个时间戳

  //  此处需要根据topFiveTimestamps中的时间戳,找到对应的列表项,并进行后续操作。
  //  例如,可以创建一个新的数组,包含前五个列表项的元素。

  // 示例:  假设每个列表项都有一个唯一的ID,可以通过ID查找
  const topFiveItems = [];
  topFiveTimestamps.forEach(timestamp => {
    const item = $(".i-list li").filter(function() {
      return Date.parse(new Date($(this).find(".time").text().replace(/-/g, "/"))) === timestamp;
    });
    topFiveItems.push(item);
  });

  //  现在 topFiveItems 数组包含了前五个时间戳对应的列表项。
  //  您可以根据需要对 topFiveItems 进行进一步处理。

}

此改进后的代码首先提取所有时间戳,然后使用sort((a, b) => b - a)进行高效的从大到小排序。 最后,使用slice(0, 5)方法获取前五个时间戳。 关键的改进在于将排序操作放在提取时间戳之后,避免了重复排序的低效操作。 代码还添加了注释,解释如何根据排序后的时间戳找到对应的列表项,并提示用户根据实际需求进行后续处理。 使用正则表达式/-/g替换所有“-”为“/”确保日期格式正确解析。

来源:1740038880