使用underscore.js按日期排序或仅使用普通JS

时间:2012-04-19 23:09:18

标签: javascript underscore.js

我有一个具有'date'字符串属性的对象数组。 即:

[
    {
        id: 1,
        startDate: '2011-4-22'
    },
    {
        id: 2,
        startDate: '2012-3-15'
    },
    {
        id: 3,
        startDate: '2011-4-22'
    },
    {
        id: 4,
        startDate: '2012-2-10'
    }
]

我只想将日期字符串转换为日期并按startDate DESC对它们进行排序。有人可以用teh underscore.js _sortBy方法告诉我如何做到这一点,甚至只是简单的javascript会做。

谢谢!

4 个答案:

答案 0 :(得分:15)

Underscore解决方案可能如下所示:

a = [ /* ... */ ];

function to_date(o) {
    var parts = o.startDate.split('-');
    o.startDate = new Date(parts[0], parts[1] - 1, parts[2]);
    return o;
}
function desc_start_time(o) {
    return -o.startDate.getTime();
}
var b = _.chain(a)
         .map(to_date)
         .sortBy(desc_start_time)
         .value();

当然,您不必使用命名函数,但名称确实使逻辑更清晰。

演示:http://jsfiddle.net/ambiguous/qe9sZ/

在纯JavaScript中你可以这样做:

for(var i = 0, parts; i < a.length; ++i) {
    parts = a[i].startDate.split('-');
    a[i].startDate = new Date(parts[0], parts[1] - 1, parts[2]);
}
var b = a.sort(function(a, b) {
    return b.startDate - a.startDate;
});

演示:http://jsfiddle.net/ambiguous/rPAPG/

答案 1 :(得分:4)

forEachsort应该为您处理:

var data = [
    {
        id: 1,
        startDate: '2011-4-22'
    },
    {
        id: 2,
        startDate: '2012-3-15'
    },
    {
        id: 3,
        startDate: '2011-4-22'
    },
    {
        id: 4,
        startDate: '2012-2-10'
    }
];

var i, c;

for(i = 0; c = data[i]; i++) {
    var parts = c.startDate.split('-');

    c.startDate = new Date(+parts[0], +parts[1] - 1, +parts[2]);
}

data.sort(function(a, b) {
    return b.startDate - a.startDate;
});

Here's a demo;检查你的控制台。

答案 2 :(得分:0)

我是这样做的:

 var sorted = _(list).sortBy(
                    function (item) {                        
                        return [new Date(item.effectiveDate).getTime(), item.batchId];
                    }), "batchId");

如果你想让它下降那么它就是* -1

 var sorted = _(list).sortBy(
                    function (item) {                        
                        return [new Date(item.effectiveDate).getTime()*-1, item.batchId];
                    }), "batchId");

在这个例子中,我按两个字段排序,你可以忘记item.batchId。

希望这有助于某人。

答案 3 :(得分:0)

如果要从数据库中获取datetime字段,则可以将datetime转换为时间戳然后排序。然后反转数组。

const _ = require('underscore');

var object = [{title:"a", date:"2018-03-22T09:10:21.000Z"}, {title:"b", date:"2018-08-22T09:10:21.000Z"}, {title:"c", date:"2018-04-22T09:10:21.000Z"}];

withTimeStamp = _.map(object, function(val, key){ 
		val.timestamp = new Date(val.date).getTime();
		return val; 
	});

object = _.sortBy(object, 'timestamp');
object.reverse();

console.log(object);