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

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

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

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


当前回答

谢谢Ganesh Sanap。按日期字段从旧到新对项目进行排序。使用它

 myArray = [{transport: "Air",
             load: "Vatican Vaticano",
             created: "01/31/2020"},
            {transport: "Air",
             load: "Paris",
             created: "01/30/2020"}] 

        myAarray.sort(function(a, b) {
            var c = new Date(a.created);
            var d = new Date(b.created);
            return c-d;
        });

其他回答

你可以在下划线js中使用sortBy。

http://underscorejs.org/#sortBy

示例:

var log = [{date: '2016-01-16T05:23:38+00:00', other: 'sample'}, 
           {date: '2016-01-13T05:23:38+00:00',other: 'sample'}, 
           {date: '2016-01-15T11:23:38+00:00', other: 'sample'}];

console.log(_.sortBy(log, 'date'));

带日期的字符串在JavaScript中是可比较的(如果它们在语法上相同),例如:

'2020-12-01' < '2020-12-02' == true

这意味着你可以在自定义排序函数中使用这个表达式:

var arr = [{id: 1、日期:“2020-12-01”},{id: 1、日期:“2020-12-15”},{id: 1、日期:' 2020-12-12 '}) 函数sortByDate(a, b) { 如果(a.date < b.date) { 返回1; } If (a.date > b.date) { 返回1; } 返回0; } const sorted = arrr .sort(sortByDate); console.log(排序);

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

db.collection.find({}).sort("your date field");  
For example:  
db.collection.find({}).sort("createdAt");  

我能够实现排序使用以下行:

array.sort(function(a, b)
{
   if (a.DueDate > b.DueDate) return 1;
   if (a.DueDate < b.DueDate) return -1;
})

使用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变量的值。