5

我有一个具有“日期”字符串属性的对象数组。IE:

[
    {
        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 对其进行排序。有人可以告诉我如何使用 underscore.js _sortBy 方法来做到这一点,甚至只是简单的 javascript 都可以。

谢谢!

4

4 回答 4

15

下划线解决方案可能如下所示:

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/

于 2012-04-20T00:08:56.620 回答
4

forEach并且sort应该为您处理:

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

这是一个演示;检查您的控制台。

于 2012-04-19T23:13:25.820 回答
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。

希望这可以帮助某人。

于 2015-11-24T17:48:32.317 回答
0

如果您从数据库中获取日期时间字段,那么您可以将日期时间转换为时间戳,然后进行排序。然后反转数组。

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

于 2018-03-29T05:41:32.093 回答