【按照年月去统计信息并分类展示】

2 篇文章 0 订阅
2 篇文章 0 订阅

1. 前言

需求是需要将历史订单按照年月分类展示,并展示汇总值。由于后端返回的是数组的数据,并没有将数据做好统计分类,出于对自己的自信以及不想给别人添麻烦的信息,然后自己写了一下处理的方法,然后放上最后的效果图吧

2. 代码实现

// 按照月份统计每个月的乘客记录
const getList = computed(() => {
  // 将数据按照时间倒叙排列
  const dataList = historyList.sort((a:any, b:any) => new Date(b.inTransDate.replace(/-/g, '/')) - new Date(a.inTransDate.replace(/-/g, '/')))
  // 获得每条数据的年月日
  const dateList = dataList.map((item:any) => item.inTransDate)
  .map((ele:any) => ele.split(' ')[0])
  // 获取去重的按年月分类的数组 new Set 可以实现数组去重
  const yearMonthList = [... new Set(dateList.map((item:any)=> item.substring(0, 7)))]
  const result:any = []  // 返回的最终结果数组
  // 根据年月数组去处理接口的返回数据,按照年月去分类
  yearMonthList.forEach(item => {
    const obj:any = {
      date: item,
      children: [],
      total: 0
    }
    dataList.forEach((ele:any) => {
      if(ele.inTransDate.indexOf(item) > -1) {
        obj.total += Number(ele.orderAmount) // 计算该月份的总金额
        obj.children.push(ele)
      }
    })
    // console.log(1111111, obj)
    result.push(obj)
  })
  return result
})

3. 效果图

在这里插入图片描述

就这样实现啦 主要是对数组的熟练操作,其中还有一个兼容ios系统的时间展示处理,千万不要踩坑啊 哈哈哈哈

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值