由于某些奇怪的原因,我编写的以下函数用于将日期字符串数组转换为javascript日期对象,对它们进行排序,然后返回一个排序日期字符串数组,这些函数没有正确排序:
sortdates: function(dates, separator) {
var sorteddates = [],
datestr =[];
sorteddates = dates.map(function(val) {
return new Date(val.replace("/"+separator+"/g", " "));
}).sort();
for ( i=0; i<sorteddates.length; i++ ) {
datestr.push((sorteddates[i].getMonth()+1) + "-" + sorteddates[i].getDate() + "-" + sorteddates[i].getFullYear());
}
return datestr;
}
如果我制作日期字符串的测试数组并应用此函数:
var testarray = ["2013-8-1", "2013-8-8", "2013-8-15", "2013-8-22", "2013-9-5", "2013-9-12", "2013-8-2", "2013-8-3", "2013-8-4", "2013-8-7", "2013-8-11", "2013-8-14", "2013-8-18", "2013-8-25"];
console.log(sortdates(testarray, "-"));
我将以下内容记录到控制台:
["8-2-2013", "8-3-2013", "8-4-2013", "8-11-2013", "8-18-2013", "8-25-2013", "8-1-2013", "8-8-2013", "8-15-2013", "8-22-2013", "9-5-2013", "9-12-2013", "8-7-2013", "8-14-2013"]
显然没有排序。
答案 0 :(得分:1)
.sort()
将按“字典”顺序排序,而不是数字或日期/时间顺序。如果值不是字符串,则它们将获得默认字符串转换,对于日期而言,它不会为您提供有用的排序功能。
但是你可以提供一个知道如何排序日期的自定义排序回调:
.sort(function(a,b) { return a.getTime() - b.getTime(); });
答案 1 :(得分:1)
sort()
将根据数组中条目的字符串表示进行排序。在这种情况下,Date的字符串表示形式类似于Thu Aug 01 2013 00:00:00 GMT-0700 (PDT)
,因此主要排序将按星期几按字母顺序排列。
Fri Aug 02 2013 00:00:00 GMT-0700 (PDT)
Sat Aug 03 2013 00:00:00 GMT-0700 (PDT)
Sun Aug 04 2013 00:00:00 GMT-0700 (PDT)
Sun Aug 11 2013 00:00:00 GMT-0700 (PDT)
Sun Aug 18 2013 00:00:00 GMT-0700 (PDT)
Sun Aug 25 2013 00:00:00 GMT-0700 (PDT)
Thu Aug 01 2013 00:00:00 GMT-0700 (PDT)
Thu Aug 08 2013 00:00:00 GMT-0700 (PDT)
Thu Aug 15 2013 00:00:00 GMT-0700 (PDT)
Thu Aug 22 2013 00:00:00 GMT-0700 (PDT)
Thu Sep 05 2013 00:00:00 GMT-0700 (PDT)
Thu Sep 12 2013 00:00:00 GMT-0700 (PDT)
Wed Aug 07 2013 00:00:00 GMT-0700 (PDT)
Wed Aug 14 2013 00:00:00 GMT-0700 (PDT)
您可能希望查看使用自定义排序回调函数或日期的其他表示形式 - 可能首先将数组映射到时间戳值而不是Date
对象?
return new Date(/* stuff */).getTime();
...以及稍后在函数中对格式化代码的相应更改。
把这一切放在一起,像这样的函数会像你期望的那样工作:
sortdates: function(dates, separator) {
return dates.map(function(val) {
return new Date(val.replace("/"+separator+"/g", " ")).getTime();
}).sort().map(function(val) {
var d = new Date(val);
return (d.getMonth()+1) + "-" + d.getDate() + "-" + d.getFullYear();
});
}