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

问题描述 投票:5回答:4

我有一个具有'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会这样做。

谢谢!

javascript underscore.js
4个回答
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();

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

但是:Kua zxsw指出

在纯JavaScript中你可以这样做:

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

但是:Kua zxsw指出


4
投票

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/应该为你处理:

forEach

sort;检查你的控制台。


0
投票

我是这样做的:

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;
});

如果你想要它下降然后它是相同的东西,但* -1

Here's a demo

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

希望这有助于某人。


0
投票

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

 var sorted = _(list).sortBy(
                    function (item) {                        
                        return [new Date(item.effectiveDate).getTime(), item.batchId];
                    }), "batchId");
© www.soinside.com 2019 - 2024. All rights reserved.