开发者社区> 问答> 正文

请问怎么把YYYY-MM-DD格式的json数据按月份分组?

查询出来类似这样的数据(大概意思):

[{

"id": 1,
"flightDate": "2016-05-11"

}, {

"id": 2,
"flightDate": "2016-05-10"

}, {

"id": 3,
"flightDate": "2016-05-09"

}, {

"id": 4,
"flightDate": "2016-05-08"

}, {

"id": 5,
"flightDate": "2016-05-07"

}]
这个json数据每条都是实体,然后输出却是按月份的。
然后页面的展示是这样的:
2016年5月
序号 人名 5月10日
序号 人名 5月09日
序号 人名 5月08日
2016年4月
序号 人名 4月07日
序号 人名 4月06日
序号 人名 4月05日
...
就是说要把这些json数据套在页面上,但是感觉html页面上循环就感觉有点困难,怎么把这个json数据重新排序以便循环输出呢?

我想的是查询出来的时间格式已经是字符串了,用字符串对比判断相同月份,然后来按月份分组,应该怎么做呢?

展开
收起
a123456678 2016-03-13 11:40:16 2335 0
1 条回答
写回答
取消 提交回答
  • var data = [{
            "id": 1,
            "flightDate": "2016-05-11"
        }, {
            "id": 2,
            "flightDate": "2016-05-10"
        }, {
            "id": 3,
            "flightDate": "2016-05-09"
        }, {
            "id": 4,
            "flightDate": "2016-04-08"
        }, {
            "id": 5,
            "flightDate": "2016-04-07"
        }, {
            "id": 6,
            "flightDate": "2016-03-06"
        }, {
            "id": 7,
            "flightDate": "2016-03-05"
        }];
        var d = [];
        var a = 0;
        d[a] = [data[0]];
        for(var i=1;i<data.length;i++){
            var t = data[i]['flightDate'].split('-');
            var f = data[i-1]['flightDate'].split('-');
            if(t[1]==f[1]){
                d[a].push(data[i]);
            }else{
                a = a+1;
                d[a] = [];
                d[a].push(data[i]);
            }
        }
        console.log(d);

    写的有点low,不知道是不是你想要的
    (前提是你的数据是按时间顺序排列出来的)

    2019-07-17 19:02:21
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载