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)
  • 相关阅读:
    Oracle学习笔记:使用replace、regexp_replace实现字符替换、姓名脱敏
    Oracle学习笔记:外连接(+)的用法
    Oracle学习笔记:with as子查询用法
    Oracle学习笔记:a inner join b与from a,b where a.x=b.x的差异
    oracle查看表,索引,视图,存储过程的定义
    oracle查看监听状态
    由sock引起的感想
    xargs
    oracle知识点小结1
    Oracle系统权限列表
  • 原文地址:https://www.cnblogs.com/yuzhengbo/p/6408512.html
Copyright © 2011-2022 走看看