cro*_*com 3 javascript momentjs lodash
我有以下数组,其中包含下面定义的 JSON 对象
[
{
"modDate": "2017-06-20"
},
{
"modDate": "2017-10-24"
},
{
"modDate": "2017-08-03"
}
]
Run Code Online (Sandbox Code Playgroud)
我希望结果首先按月分组,然后按月降序排序。
我试过用这个分组
grouped_items = _.groupBy(data, (b) ->
moment(b.modDate).startOf('month').format('YYYY/MM')
Run Code Online (Sandbox Code Playgroud)
但没有得到正确的结果。
如果我理解正确,您想按月创建数据的分组集合,然后按月中的天降序对值进行排序(因为按月对值进行排序没有意义)。
如果是这样,以下应该有效:
const data = [{"modDate":"2017-06-20"},{"modDate":"2017-06-25"},{"modDate":"2017-10-24"},{"modDate":"2017-10-20"},{"modDate":"2017-08-03"}];
let grouped_items = _.groupBy(data, (b) =>
moment(b.modDate).startOf('month').format('YYYY/MM'));
_.values(grouped_items)
.forEach(arr => arr.sort((a, b) => moment(a.modDate).day() - moment(b.modDate).day()));
console.log(grouped_items);Run Code Online (Sandbox Code Playgroud)
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.10/lodash.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.22.1/moment.min.js"></script>Run Code Online (Sandbox Code Playgroud)