首页前端开发JavaScriptjavascript中怎么将一维数组转为三维数组?方法介绍

javascript中怎么将一维数组转为三维数组?方法介绍

时间2024-01-31 03:41:03发布访客分类JavaScript浏览689
导读:收集整理的这篇文章主要介绍了javascript中怎么将一维数组转为三维数组?方法介绍,觉得挺不错的,现在分享给大家,也给大家做个参考。javascript中怎么将一维数组转为三维数组?本篇文章就来给大家分享一种转换方法,JS一维数组转化为...
收集整理的这篇文章主要介绍了javascript中怎么将一维数组转为三维数组?方法介绍,觉得挺不错的,现在分享给大家,也给大家做个参考。javascript中怎么将一维数组转为三维数组?本篇文章就来给大家分享一种转换方法,JS一维数组转化为三维数组有这个方法就够了!

今天看到一个提问的小伙伴,是想要将一维数组转化为三位数组的需求,正好不是很忙,乐于助人的我立马给这位同学安排上

下面是后端同学返给我们的一维数组数据格式

	[{
      '品牌': 'xiaomi', '机型': '10', '配置': '512'    }
,    {
      '品牌': 'xiaomi', '机型': '10', '配置': '128'    }
,    {
      '品牌': 'xiaomi', '机型': '11', '配置': '128'    }
,    {
      '品牌': 'xiaomi', '机型': '11', '配置': '64'    }
,    {
      '品牌': 'iPhone', '机型': '10', '配置': '128'    }
,    {
      '品牌': 'iPhone', '机型': '11', '配置': '64'    }
,    {
      '品牌': 'iPhone', '机型': '12', '配置': '64'    }
,    {
      '品牌': 'honor', '机型': '4', '配置': '256'    }
,    {
      '品牌': 'honor', '机型': '5', '配置': '128'    }
,    {
      '品牌': 'honor', '机型': '6', '配置': '128'    }
    ];
    

下面是我们想要转化的数据格式(转化成三维数组 第一层级为品牌、第二层级为型号、第三层级为配置)

    [      {
        "value": "xiaomi",        "label": "xiaomi",        "children": [          {
            "value": "10",            "label": "10",            "children": [              {
                "value": "512",                "label": "512"              }
,              {
                "value": "128",                "label": "128"              }
            ]          }
,          {
            "value": "11",            "label": "11",            "children": [              {
                "value": "128",                "label": "128"              }
,              {
                "value": "64",                "label": "64"              }
            ]          }
        ]      }
,      {
        "value": "iPhone",        "label": "iPhone",        "children": [          {
            "value": "10",            "label": "10",            "children": [              {
                "value": "128",                "label": "128"              }
            ]          }
,          {
            "value": "11",            "label": "11",            "children": [              {
                "value": "64",                "label": "64"              }
            ]          }
,          {
            "value": "12",            "label": "12",            "children": [              {
                "value": "64",                "label": "64"              }
            ]          }
        ]      }
,      {
        "value": "honor",        "label": "honor",        "children": [          {
            "value": "4",            "label": "4",            "children": [              {
                "value": "256",                "label": "256"              }
            ]          }
,          {
            "value": "5",            "label": "5",            "children": [              {
                "value": "128",                "label": "128"              }
            ]          }
,          {
            "value": "6",            "label": "6",            "children": [              {
                "value": "128",                "label": "128"              }
            ]          }
        ]      }
        ]

首先我们定义一个arr变量接收我们的一维数组,然后将arr作为参数传递给我们转化数组的函数,函数返回的就是我们最终的三维数组了

下面就是我们的arrConversion源码

    arrConversion (arr) {
          let keys = Object.keys(arr[0])      let level1 = keys[0]//获取一级属性名称      let level2 = keys[1]//获取二级属性名称      let level3 = keys[2]//获取三级属性名称      let list = Array.From(new Set(        arr.map(ITem =>
 {
          return item[level1]        }
    )))      let subList = []      list.foreach(res =>
 {
            arr.forEach(ele =>
 {
          if (ele[level1] === res) {
                let nameArr = subList.map(item =>
 item.value)            if (nameArr.indexOf(res) !== -1) {
                  let nameArr2 = subList[nameArr.indexOf(res)].children.map(item =>
 item.value)              if (nameArr2.indexOf(ele[level2]) !== -1) {
                subList[nameArr.indexOf(res)].children[nameArr2.indexOf(ele[level2])].children.push({
                  value: ele[level3],                  label: ele[level3],                }
)              }
 else {
                subList[nameArr.indexOf(res)].children.push({
                  value: ele[level2],                  label: ele[level2],                  children: [{
                    value: ele[level3],                    label: ele[level3],                  }
]                }
)              }
            }
 else {
              subList.push({
                value: res,                label: res,                children: [{
                  value: ele[level2],                  label: ele[level2],                  children: [{
                    value: ele[level3],                    label: ele[level3],                  }
]                }
]              }
)            }
          }
        }
)      }
)      return subList    }
    

输出结果正确

【相关推荐:javascript学习教程

以上就是javascript中怎么将一维数组转为三维数组?方法介绍的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

javascript

若转载请注明出处: javascript中怎么将一维数组转为三维数组?方法介绍
本文地址: https://pptw.com/jishu/593433.html
C中如何声明指向函数的指针? 在C++中对象如何作为参数传递和返回?(代码示例)

游客 回复需填写必要信息