从大到小排序列表中前五条数据的时间戳
挑战: 如何高效地根据时间戳,从大到小排序列表中的前五条数据?
解决方案:
原始代码的错误在于它在每次迭代中都进行排序,导致效率低下且结果不正确。 正确的做法是先提取所有时间戳,再进行排序,最后取前五名。
改进后的代码:
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替换所有“-”为“/”确保日期格式正确解析。
以上就是如何高效地根据时间戳从大到小排序列表中的前五条数据?的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2797633.html