开发过程中经常会遇到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 += '<div class="weui-cells__title">'+v[0]+'</div>'+
'<div class="weui-cells">';
$.each(v[1],function(kk,vv){
var point = vv.status==1?'+'+vv.number:'-'+vv.number
var point_class = vv.status==1?'colororg':''
html += '<div role="option" class="weui-cell ">'+
'<div class="weui-cell__bd weui-media-box_text">'+
'<h4 class="weui-media-box__title">'+vv.type_name+'</h4>'+
'<div class="weui-media-box__desc">'+vv.create_time+'</div>'+
'</div>'+
'<div class="weui-cell__ft '+point_class+'">'+point+'</div>'+
'</div>';
});
html += '</div>';
});