web-dev-qa-db-ja.com

アンダースコアsortByを使用したオブジェクトソートの配列

この配列があります。アンダースコア「_.sortBy」を使用して開始日に従ってソートするにはどうすればよいですか?

[
    { 
        id: 'oljw832021kjnb389xzll323jk',
        start: { dateTime: '2013-09-26T13:30:00-07:00' },
        end: { dateTime: '2013-09-26T14:30:00-07:00' },
    },
    { 
        id: 'ed7l5tmckdp0lm90nvr4is3d4c',
        start: { dateTime: '2013-09-26T15:30:00-07:00' },
        end: { dateTime: '2013-09-26T16:30:00-07:00' },
    },
    { 
        id: 'etmasdsackdp0kjl0nvrkopioqw',
        start: { dateTime: '2013-09-26T18:00:00-07:00' },
        end: { dateTime: '2013-09-26T19:00:00-07:00' },
    }
]
66
Jack Dre

プロパティに単一の文字列ではなく、反復関数を使用します。

_.sortBy(arr, function(o) { return o.start.dateTime; })
158
Bergi

私はこのようにしました:

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

この例では、2つのフィールドで注文していますが、item.batchIdを忘れることができます。

これが誰かを助けることを願っています。

2
Sanchitos