数组对象线性和树形结构的转换

线性转树形

jsonToTree = (arr) => {
	let map = {};
	arr.forEach(v => {
		map[v.id] = v;
	});
	
	let tree = [];
	arr.forEach(item => {
		const mapItem = map[item.pid];
		if (mapItem) {
			(mapItem.children || (mapItem.children = [])).push(item);
		} else {
			tree.push(item);
		}
	});

	return tree;
}
jsonToTree([{id: 1, name: '1'},{id: 2, name: '2'},{id: 3, pid: 1, name: '1-3'},{id: 4, pid: 2, name: '2-4'}])

树形转线性

var arr = []
treeToJson = (tree,pid) => {
	if (tree.length) {
		tree.forEach((d,i)=>{
			if(d.children && d.children.length){
				treeToJson(d.children,d.id);
				delete d.children
			}
			if(pid) d.pid = pid
			arr.push({...d})
		})
	}
} 
treeToJson([{id: 1,name: "1",children:[{id: 3, name: "1-3"},{id: 4, name: "1-5"}]},{id: 2,name: "2",children:[{id: 4, name: "2-4"}]}])
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值