美文网首页
js 数组变成树结构

js 数组变成树结构

作者: _theFeng | 来源:发表于2019-10-23 17:46 被阅读0次
const obj = {}
let arr = [
     {
    id: 20, // id
    // pid: 5 // 父级id
  },
  {
    id: 10, // id
    pid: 5 // 父级id
  },
  {
    id: 1,
    pid: 2
  },
  {
    id: 3,
    pid: 4
  },
  {
    id: 2,
    pid: 3
  },
  {
    id: 100,
    pid: 5
  },
  {
    id: 10099,
    pid: 6
  },
  {
    id: 1000,
    pid: 100
  }
]

arr.forEach((i, index) => {
    i.index = index
    obj[i.id] = i
})

arr.forEach((i, index) => {
    if (i.pid) {
        if (obj[i.pid]) {
            let pitem = arr[obj[i.pid].index]
            if (!pitem.c) pitem.c = []
            pitem.c.push(i)
            i.r = true
        }
    }
})

let newarr = arr.filter(i => !i.r)

console.log(newarr)

相关文章

  • js 数组变成树结构

  • js 数组截取 变成树结构

    需要对数组进行截取,一般是使用循环,现在发现一个方式: array.splice(开始删除的index,结束删除的...

  • js 数组去重,格式转换方法

    1,对象数组去重 2,用js实现将二维数组格式化转换成树状数组 3,将树结构数据转换为一维数组 4, 数组去重

  • 递归实现树结构

    JS递归算法实现 数组 转 树结构 根节点只有一个 得到树结构如下: 2.多个根节点上例是指定只有一个根节点,可以...

  • 9. 进阶算法之"搜索排序"

    简介 排序: 把某个乱序的数组变成升序或者降序的数组 搜索:找出数组中某个元素的下标 JS中的排序和搜索 JS中的...

  • JS 二维数组转树结构

    学习了一下class类 用class类简单写一个

  • JS数组和树结构之间的转换

    解答如下: 测试一下: 解答如下: 测试一下: --END--

  • 排序和搜索

    1. 是什么 排序:把某个乱序的数组变成升序或者降序的数组。js 中的排序:数组的 sort 方法。 搜索:找出数...

  • 【转】js数组和树结构数据相互转换

    数组转树结构采取递归和非递归两种方式,树结构转扁平化数组采取深度优先遍历(递归和非递归两种方式)和广度优先遍历实现...

  • js-数组的基本操作

    本文主要介绍js数组元素的一些基本操作,常用的一些方法 关键词:创建数组、新增数组元素、删除数组元素、将数组变成字...

网友评论

      本文标题:js 数组变成树结构

      本文链接:https://www.haomeiwen.com/subject/ewgkvctx.html