查询出来类似这样的数据(大概意思):
[{
"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,不知道是不是你想要的
(前提是你的数据是按时间顺序排列出来的)
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。