数据分组展示有两种方式,一种是后端直接传入分组格式的Json数据,另一种是我们在前端自己转换格式,这里我们在前端处理转换按日期分组的数据格式

1、例如后端返回数据格式为:

  1. [{createtime:'2019-07-29',content:'哈哈哈'},{createtime:'2019-07-29',content:'哈哈哈'}]

2、页面展示需要的格式为:

  1. [{createtime:'2019-07-29',list:[{createtime:'2019-07-29',content:'哈哈哈'},{createtime:'2019-07-29',content:'哈哈哈'}]}]

3、下面我们使用Js处理成按日期分组归类的数据,代码如下:

  1. let newArr = [];
  2. _list.forEach((item,i)=>{
  3. let index = -1;
  4. let isExists = newArr.some((newItem,j)=>{
  5. if(item.createtime==newItem.createtime){
  6. index = j;
  7. return true;
  8. }
  9. })
  10. if(!isExists){
  11. newArr.push({
  12. createtime:item.createtime,
  13. timeDay:item.timeDay,
  14. timeMonth:item.timeMonth,
  15. subList:[item]
  16. })
  17. }else{
  18. newArr[index].subList.push(item);
  19. }
  20. })

4、处理后的结果:

  1. [
  2. {
  3. "createtime":"2019-07-27",
  4. "timeDay":27,
  5. "timeMonth":7,
  6. "subList":[
  7. {
  8. "group_post_id":128,
  9. "group_id":0,
  10. "group_topic_id":"",
  11. "uid":73,
  12. "nickname":"阿健w ",
  13. "avatar_url":"https://wx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTKicUgL8bc6EDmPcST3ozT00OZTpmJSrpcFaB3Fjfp5b4PWNxEraKu1wviaIicxVcRzxOE7FfLRYFOTg/132",
  14. "content":"哈哈哈",
  15. "longitude":116.340988,
  16. "latitude":40.006805,
  17. "province":"",
  18. "city":"",
  19. "location":"",
  20. "address":"",
  21. "like_count":0,
  22. "comment_count":0,
  23. "status":"0",
  24. "createtime":"2019-07-27",
  25. "pics":[
  26. ],
  27. "timeDay":27,
  28. "timeMonth":7
  29. }
  30. ]
  31. }]

问题:

以上这种方式处理在正常情况下是没有问题的,但通常我们在分组显示的时候会存在分页的问题,可以看到下图出现了两个相同的日期,是因为同一天的分组数据不能一页展示完,可能会在第二页或者第三页出现的情况

解决:

方式1:

参考我之前的一个做法https://www.cnblogs.com/fozero/p/7599785.html

  1. if(pageNum==1){
  2. this.list = newArr;
  3. }else{
  4. // 解决分组分页问题
  5. // 遍历newArr 与上页最后一条记录日期比较,相同日期则直接追加
  6. for(let i in newArr){
  7. if(newArr[i].createtime==this.list[this.list.length-1].createtime){
  8. this.list[this.list.length-1].subList = this.list[this.list.length-1].subList.concat(newArr[i].subList);
  9. }else{
  10. this.list.push(newArr[i]);//数组追加
  11. }
  12. }
  13. }

方式2:

参考使用后端mysql分组查询并按照分组条数来进行分页

https://www.cnblogs.com/jackyfee/archive/2011/05/07/GroupPage.html

https://blog.csdn.net/zhang197093/article/details/49425261

小程序开发笔记(八)—Js数组按日期分组显示数据的更多相关文章

  1. 小程序开发笔记【二】,抽奖结果json数据拼装bug解决

    抽奖结果数据json格式数据拼接bug,如下图,只发布了两个奖项,每个奖项设置2个奖品,但最后拼接数据的时候出现3个奖项 json数据格式如下 "luckyResult":[ { ...

  2. 微信小程序开发笔记02

    今天学习了微信小程序开发用到的语言,wxml与wxss语言基本语法与html和css基本语法相似,学习起来相对简单.在小程序主要的语言是js(javascript,跟准确的说是jqery) ,由于这种 ...

  3. 微信小程序开发笔记01

    微信小程序开发的优势 1,不用安装,即开即用,用完就走.省流量,省安装时间,不占用桌面: 2,体验上虽然没法完全媲美原生APP,但综合考虑还是更优: 3,对于小程序拥有者来说,开发成本更低,他们可以更 ...

  4. 微信小程序开发笔记(一)

    一.为什么要学习微信小程序开发 微信小程序是一个可以在微信上打开的轻应用,他是由多个页面组成的程序,跟传统APP比较如下: 优点 1.不需要在应用商店下载,不占用内存空间,即开即用 2.可以在微信内直 ...

  5. 微信小程序开发笔记

    前言: 因为前段时间一直在做关于微信小程序方面的项目,作为一名后端的攻城狮而言做一些简单的前端页面数据操作和管理还是比较容易快上手的,当然前提是要理解微信小程序的基本语法和请求原理.该篇博客主要记录的 ...

  6. 微信小程序开发笔记(二)

    一.前言 继承上一篇所说的,有了对微信小程序的基础概念后,这边将会示范动手做一个小程序,在动手的过程中我们可以更快的熟悉小程序里面的架构和开发流程. 二.小程序的设计 这次要做的是一个猜数字的程序,程 ...

  7. 微信小程序开发笔记04

    今天将小程序的页面进行优化 消除昨天遇到的bug问题. 完成了微信小程序的开发.

  8. 微信小程序开发笔记03

    今天基本实现了微信小程序主要功能,页面还没有进行优化,有些功能还需完善. 页面之间的信息转化部分还未实现.

  9. 微信小程序开发之拼接json数组字符串

    直接上代码   : var imageitem;    var imageitemstring='';    for(var i=0;i< that.data.fbimages.length;i ...

随机推荐

  1. C#截图操作(几种截图方法)

    公共函数获取屏幕截图private Bitmap GetScreenCapture(){ Rectangle tScreenRect = new Rectangle(0, 0, Screen.Prim ...

  2. Elastic:用Docker部署Elastic栈

    安装 因为我们需要使用docker来进行安装,我们必须安装: docker:根据不同的操作系统,请按照要求安装docker.可以到网站https://docs.docker.com/去安装 docke ...

  3. Flask笔记:信号机制

    Flask中有内置的一些信号,也可以通过三方库blinker自定义信号,其实Flask内置的信号也是优先使用的blinker库,如果没有安装blinker才会使用自定义的信号机制.可以通过点击任意导入 ...

  4. Python-标准库(常用模块)

    前言: 之所以为不同模块划分重要程度,是因为大家不不可能精力一直集中,也不可能一下掌握所有, 但这个并不表示重要度低的可以不用掌握 ! 你必须掌握的点是每个模块分别干什么事,今后在需要实现某些功能时能 ...

  5. Winform中怎样获取项目图片资源并转换为Image对象

    场景 DevExpress的TreeList怎样给树节点设置图标: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10274554 ...

  6. curl ftp libcurl 功能使用

    struct FtpFile { const char *filename; FILE *stream; }; static size_t my_fwrite(void *buffer, size_t ...

  7. 真机调试(A valid provisioning profile for this executable was not found.)

    这个问题是因为provisioning的问题,因为真机没有加入到账号下面的原因 解决步骤 1.吧identifier复制然后再平开开发中心 2.点击+号添加设备保存 3.在develope中选中保存即 ...

  8. Qt开源编辑器qsciscintilla的一些用法

    首先放一张自己做的软件中的编辑器的效果图 中间红色的框就是放在Qt的tabwidget控件中的qsciscintilla编辑器 先从官网下载qsciscintilla源码,在qtcreater中编译, ...

  9. PyCharm颜色设置

    选择主题和背景图片 选择字体.修改字体大小 新建颜色主题 修改背景颜色 修改注释颜色 File --> Setting (Ctrl + Shift + S) 1.选择不同的主题.选择背景图片 A ...

  10. firewalld基础

    firewalld是一个基于网络区域的动态管理防火墙的守护进程.在iptables中需要理解表,链等概念,而在firewalld中需要从理解区域的概念开始 防火墙依照特定的规则允许或限制输出的数据通过 ...