この配列があります。アンダースコア「_.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' },
}
]
プロパティに単一の文字列ではなく、反復関数を使用します。
_.sortBy(arr, function(o) { return o.start.dateTime; })
私はこのようにしました:
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を忘れることができます。
これが誰かを助けることを願っています。