数组按月份排序

在开发中遇到后端未排序的数据数组,需要前端自己进行处理。文章提供了一个JavaScript方法,首先检查时间戳并将其转换为日期格式,然后使用`reduce`方法按月份对数组重新排序。代码示例展示了如何将时间戳转换为日期并按月份排列数组元素。

开发中遇到的一个问题根据你每个月的数据来进行排序,但是后端给了一个整个数组没有排序,需要前端自己处理,最好的解决方法就是让后端来写,但是我们后端懒,只能自己来处理啦

  1. 数组的时间如果是年月日直接跳过这一步,如果不是补充一个知识点将时间戳转为时间格式

 formatTime(time) {
      let date = new Date(time * 1000);
      let Y = date.getFullYear() + "-";
      let M =
        (date.getMonth() + 1 < 10
          ? "0" + (date.getMonth() + 1)
          : date.getMonth() + 1) + "-";
      let D =
        (date.getDate() < 10 ? "0" + date.getDate() : date.getDate()) + " ";
      let h =
        (date.getHours() < 10 ? "0" + date.getHours() : date.getHours()) + ":";
      let m =
        (date.getMinutes() < 10 ? "0" + date.getMinutes() : date.getMinutes()) +
        ":";
      let s =
        date.getSeconds() < 10 ? "0" + date.getSeconds() : date.getSeconds();
      return Y + M + D + h + m + s;
    },

这一步比较笼统自己看看就行

  1. 将数组每一项的时间戳转换

 for (let i = 0; i < this.monthlyIncome_priceFrom.length; i++) {
        this.monthlyIncome_priceFrom[i].created_at = this.formatTime( this.monthlyIncome_priceFrom[i].created_at)
      }
  1. 使用reduce对数组重新计算排列

  this.monthlyIncome_priceFrom = this.monthlyIncome_priceFrom.reduce((r, v) => r[v.created_at.split('-')[1] - 1].push(v) && r, new Array(12).fill(0).map(_ => []));
      

生成12个月份的数组根据reduce分割的相同的月份进行push

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值