zoukankan      html  css  js  c++  java
  • js按条件分类json数组,并合计同组数据(一维转换为二维)

    let _items = response.json()
          // console.log(_items.data)
          let json1 = _items.data
          let json2 = []
          let keyMap = {}
          for (let i = 0; i < json1.length; i++) {
            let json1Elem = json1[i]
            let elemKey = json1Elem.year + '-' + json1Elem.month
            if (elemKey in keyMap) {
              json2[keyMap[elemKey]].value.push(json1Elem)
            } else {
              json2.push({
                'year': json1Elem.year,
                'month': json1Elem.month,
                'value': [json1Elem],
                'goods_number': null,
                'taxless_amount': null,
                'amount': null,
                'tax': null
              })
              keyMap[elemKey] = json2.length - 1
            }
          }
          // console.log(json2)
          for (let i = 0; i < json2.length; i++) {
            json2[i].value.forEach(function (item) {
              json2[i].goods_number = null
              json2[i].taxless_amount = null
              json2[i].amount = null
              json2[i].tax = null
              function getsum (item, arry) {
                json2[i].goods_number += Number(item.goods_number)
                json2[i].taxless_amount += Number(item.taxless_amount)
                json2[i].amount += Number(item.amount)
                json2[i].tax += Number(item.tax)
              }
              json2[i].value.forEach(getsum, json2[i].value)
            })
          }
          console.log(json2)
  • 相关阅读:
    bjdctf_2020_router
    Windows下Apache配置https
    Linux定时备份数据库并删除N天以前的数据
    MySQL出现Waiting for table metadata lock的原因以及解决方法
    MySQL操作(五)查询实例
    Windows常用命令
    PHPSTORM常用快捷键
    MySQL操作(四)索引及优化
    MySQL操作(三)数据表
    MySQL操作(二)数据库
  • 原文地址:https://www.cnblogs.com/yuzhengbo/p/6408512.html
Copyright © 2011-2022 走看看