一个将扁平数组转成树形数据的非递归函数

通常我们都是通过递归的方式将扁平数组转成树形数据,这次偶然看见一位大佬写的非递归方法,记录下来学习一下。人菜就得多学习啊

/**
 * @param list 列表
 * @param id id-key
 * @param pid pid-key
 * @param rootid 根id
 * @param children children-key
 */
function toTree(list = [], { id = "id", pid = "pid", rootid = "rootid", children = "children" } = {}) {
	const parentMap = new Map(),
		topNodes = [];
	for (const item of list) {
		if (parentMap.has(item[id])) {
			item[children] = parentMap.get(item[id])[children];
		} else {
			item[children] = [];
		}
		parentMap.set(item[id], item);
		if (parentMap.has(item[pid])) {
			parentMap.get(item[pid])[children].push(item);
		} else {
			parentMap.set(item[pid], { [children]: [item] })
		}
		if (String(item[pid]) === rootid) {
			topNodes.push(item);
		}
	}
	return topNodes;
}

效果如下:

const data = [
	{
		id: "1",
		pid: "0",
		value: 1
	},
	{
		id: "2",
		pid: "1",
		value: 2
	},
	{
		id: "3",
		pid: "2",
		value: 3
	},
	{
		id: "4",
		pid: "3",
		value: 4
	}
];
console.log(toTree(data, { rootid: "0" }));

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值