假设我有一个包含几个对象的数组:

var array = [{id: 1, date: Mar 12 2012 10:00:00 AM}, {id: 2, date: Mar 8 2012 08:00:00 AM}];

如何按日期元素排序这个数组,从最接近当前日期和时间的日期下来?请记住,数组可能有许多对象,但为了简单起见,我使用2。

我会使用排序函数和自定义比较器吗?


当前回答

使用ES6箭头函数,您可以进一步编写一行简洁的代码(不包括变量声明)。

Eg.:

var isdescent = true;//升序设置为false console.log([“8/2/2020”、“8/1/2020”、“8/13/2020”、“8/2/2020”].sort ((a, b) = >板块?new Date(b).getTime() - new Date(a).getTime(): new Date(a).getTime() - new Date(b).getTime()));

由于time与上述日期不存在,Date对象将考虑以下默认时间进行排序:

00:00:00

该代码可用于升序排序和降序排序。 只需根据需要更改isdescent变量的值。

其他回答

对于任何想要按日期(英国格式)排序的人,我使用以下方法:

//Sort by day, then month, then year
for(i=0;i<=2; i++){
    dataCourses.sort(function(a, b){

        a = a.lastAccessed.split("/");
        b = b.lastAccessed.split("/");

        return a[i]>b[i] ? -1 : a[i]<b[i] ? 1 : 0;
    }); 
}

使用ES6箭头函数,您可以进一步编写一行简洁的代码(不包括变量声明)。

Eg.:

var isdescent = true;//升序设置为false console.log([“8/2/2020”、“8/1/2020”、“8/13/2020”、“8/2/2020”].sort ((a, b) = >板块?new Date(b).getTime() - new Date(a).getTime(): new Date(a).getTime() - new Date(b).getTime()));

由于time与上述日期不存在,Date对象将考虑以下默认时间进行排序:

00:00:00

该代码可用于升序排序和降序排序。 只需根据需要更改isdescent变量的值。

如果你喜欢MongoDB,其中一个解决方案是:

db.collection.find({}).sort("your date field");  
For example:  
db.collection.find({}).sort("createdAt");  
Adding absolute will give better results

var datesArray =[
      {"some":"data1","date": "2018-06-30T13:40:31.493Z"},
      {"some":"data2","date": "2018-07-04T13:40:31.493Z"},
      {"some":"data3","date": "2018-06-27T13:40:54.394Z"}
   ]

var sortedJsObjects = datesArray.sort(function(a,b){ 
    return Math.abs(new Date(a.date) - new Date(b.date)) 
});

这是解决你的问题的最短方法。

  var array = [{id: 1, date: 'Mar 12 2012 10:00:00 AM'}, {id: 2, date: 'Mar 8 2012 08:00:00 AM'}];

  var sortedArray = array.sort((a,b) => Date.parse(new Date(a.date)) - Date.parse(new Date(b.date)));