js处理json数据(合并键值对相同的数据,指定键值对相加或拼接)、前端实现

简介: js处理json数据(合并键值对相同的数据,指定键值对相加或拼接)、前端实现

方法:

// 将相同name的进行分组
          for (let i = 0; i < newArr1.length; i++) {//newArr1为原始json数据
            // 利用some函数来区分是否相同
            if (
              !obj.some(item => item.name === newArr1[i].name &&
                item.width === newArr1[i].width &&
                item.height === newArr1[i].height &&
                item.widthDeviation === newArr1[i].widthDeviation &&
                item.heightDeviation === newArr1[i].heightDeviation &&
                item.tempered === newArr1[i].tempered &&
                item.floorNum === newArr1[i].floorNum &&
                item.processRequirements === newArr1[i].processRequirements &&
                item.remark === newArr1[i].remark
              )) {
              obj.push(newArr1[i])

              arr.push({
                gname: newArr1[i].name,
                gwidth: newArr1[i].width,
                gheight: newArr1[i].height,
                gwidthDeviation: newArr1[i].widthDeviation,
                gheightDeviation: newArr1[i].heightDeviation,
                gtempered: newArr1[i].tempered,
                gfloorNum: newArr1[i].floorNum,
                gprocessRequirements: newArr1[i].processRequirements,
                gremark: newArr1[i].remark,
                data: [newArr1[i]]
              })
            } else {
              // 把那些和键值相同的条目放入分组(玻璃名)
              for (let k = 0; k < arr.length; k++) {
                if (arr[k].gname === newArr1[i].name &&
                  arr[k].gwidth === newArr1[i].width &&
                  arr[k].gheight === newArr1[i].height &&
                  arr[k].gwidthDeviation === newArr1[i].widthDeviation &&
                  arr[k].gheightDeviation === newArr1[i].heightDeviation &&
                  arr[k].gtempered === newArr1[i].tempered &&
                  arr[k].gfloorNum === newArr1[i].floorNum &&
                  arr[k].gprocessRequirements === newArr1[i].processRequirements &&
                  arr[k].gremark === newArr1[i].remark
                ) {
                  arr[k].data.push(newArr1[i])
                }
              }
            }
          }
const arr2 = []
        var newArr1s = []
        // 循环分组数据即可,然后针对特定项目做处理
        // 注意点在于三元表达式,因为数组必须有两个才能用reduce函数(缩减函数)
        arr.forEach(item => {
          console.log(`j88888---`, item)
          arr2.push({
            // name: item.data.map(item => item.name).join(','),
            name: item.gname,
            width: item.gwidth,
            height: item.gheight,
            widthDeviation: item.gwidthDeviation,
            heightDeviation: item.gheightDeviation,
            number: item.data.length > 1 ? item.data.map(item => item.number).reduce((pre, next) => pre + next) : item.data[0].number,//此处为相加方法
            price: item.data[0].price,
            tempered: item.gtempered,
            floorNum: item.gfloorNum ? item.gfloorNum : item.data.map(item => item.floorNum).join(','),
            processRequirements: item.gprocessRequirements ? item.gprocessRequirements : item.data.map(item => item.processRequirements).join(','),//此处为字符串拼接方法
            remark: item.gremark ? item.gremark : item.data.map(item => item.remark).join(',')
            // tempered: this.sss,
            // name: item.data[0].name
          })
        })

来看对比图:
合并前:
在这里插入图片描述
合并后:
在这里插入图片描述
需要的可直接贴代码。

相关文章
|
3月前
|
JSON API 数据格式
淘宝拍立淘按图搜索API系列,json数据返回
淘宝拍立淘按图搜索API系列通过图像识别技术实现商品搜索功能,调用后返回的JSON数据包含商品标题、图片链接、价格、销量、相似度评分等核心字段,支持分页和详细商品信息展示。以下是该API接口返回的JSON数据示例及详细解析:
|
3月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
3月前
|
JSON API 数据安全/隐私保护
Python采集淘宝拍立淘按图搜索API接口及JSON数据返回全流程指南
通过以上流程,可实现淘宝拍立淘按图搜索的完整调用链路,并获取结构化的JSON商品数据,支撑电商比价、智能推荐等业务场景。
|
4月前
|
JSON 缓存 自然语言处理
多语言实时数据微店商品详情API:技术实现与JSON数据解析指南
通过以上技术实现与解析指南,开发者可高效构建支持多语言的实时商品详情系统,满足全球化电商场景需求。
|
3月前
|
JSON 中间件 Java
【GoGin】(3)Gin的数据渲染和中间件的使用:数据渲染、返回JSON、浅.JSON()源码、中间件、Next()方法
我们在正常注册中间件时,会打断原有的运行流程,但是你可以在中间件函数内部添加Next()方法,这样可以让原有的运行流程继续执行,当原有的运行流程结束后再回来执行中间件内部的内容。​ c.Writer.WriteHeaderNow()还会写入文本流中。可以看到使用next后,正常执行流程中并没有获得到中间件设置的值。接口还提供了一个可以修改ContentType的方法。判断了传入的状态码是否符合正确的状态码,并返回。在内部封装时,只是标注了不同的render类型。再看一下其他返回的类型;
210 3
|
3月前
|
JSON Java Go
【GoGin】(2)数据解析和绑定:结构体分析,包括JSON解析、form解析、URL解析,区分绑定的Bind方法
bind或bindXXX函数(后文中我们统一都叫bind函数)的作用就是将,以方便后续业务逻辑的处理。
316 3
|
4月前
|
JSON API 数据安全/隐私保护
Python采集淘宝评论API接口及JSON数据返回全流程指南
Python采集淘宝评论API接口及JSON数据返回全流程指南
|
4月前
|
JSON 自然语言处理 监控
淘宝关键词搜索与商品详情API接口(JSON数据返回)
通过商品ID(num_iid)获取商品全量信息,包括SKU规格、库存、促销活动、卖家信息、详情页HTML等。
|
4月前
|
JSON 自然语言处理 API
多语言实时数据淘宝商品评论API:技术实现与JSON数据解析指南
淘宝商品评论多语言实时采集需结合官方API与后处理技术实现。建议优先通过地域站点适配获取本地化评论,辅以机器翻译完成多语言转换。在合规前提下,企业可构建多语言评论数据库,支撑全球化市场分析与产品优化。
|
4月前
|
机器学习/深度学习 JSON API
干货,淘宝拍立淘按图搜索,淘宝API(json数据返回)
淘宝拍立淘按图搜索API接口基于深度学习与计算机视觉技术,通过解析用户上传的商品图片,在淘宝商品库中实现毫秒级相似商品匹配,并以JSON格式返回商品标题、图片链接、价格、销量、相似度评分等详细信息。