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

查看:79
本文介绍了javascript - 请问怎么把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数据重新排序以便循环输出呢?

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

解决方案

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,不知道是不是你想要的
(前提是你的数据是按时间顺序排列出来的)

这篇关于javascript - 请问怎么把YYYY-MM-DD格式的json数据按月份分组?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆