开发过程中经常会遇到UI将列表页设计成按日期分组来显示数据

我的解决方案是后台正常返回数据,由前端处理数据显示。
1.后台返回的列表数据中返回了一个字段create_month,这个字段就是方便前端分组的,Y-m-d的格式。
let groupData = new Map()
res.data.forEach(item=>{
let [date, time] = item.create_month.split(" ")
item.date = date
item.time = time
if(!groupData.has(date)) {
groupData.set(date, [item])
} else {
groupData.get(date).push(item)
}
})
let groupDataArr = [...groupData.entries()]
然后将groupDataArr数据二次循环输出,就可以得到上面图片的效果。
var html = '';
$.each(groupDataArr, function(k,v) {
html += ''+v[0]+''+
'';
$.each(v[1],function(kk,vv){
var point = vv.status==1?'+'+vv.number:'-'+vv.number
var point_class = vv.status==1?'colororg':''
html += ''+
''+
''
+vv.type_name+''+
''+vv.create_time+''+
''+
''">'+point+''+
'';
});
html += '';
});