js将list数据按日期分组

开发过程中经常会遇到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>';
});
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值