js树形结构数据,为每个顶级节点的 children 添加 parentName 属性

数据结构和递归函数

// 数据结构
const arr = [  
  {  
    name: "测试1",  
    parentId: 0,  
    cityId: 1,  
    children: [  
      {  
        name: "测试2",  
        parentId: 1,  
        cityId: 2,  
        children: [  
          { name: "测试7", parentId: 2, cityId: 7 },  
          { name: "测试8", parentId: 2, cityId: 8 },  
        ],  
      },  
      { name: "测试3", parentId: 1, cityId: 3 },  
    ],  
  }  
];  
  
// 递归函数来设置 parentName  
function setParentNames(nodes, parentName = null) {  
  nodes.forEach(node => {  
    // 设置当前节点的 parentName  
    node.parentName = parentName; 
    if (node.children && node.children.length > 0) {  
      // 递归处理子节点,并传递当前节点的 name 作为 parentName  
      setParentNames(node.children, node.name); 
    }  
  });  
}  
  

调用方法

若只有一个顶级节点

// 调用函数,从顶级节点的 children 开始  
if (arr.length > 0 && arr[0].children) {  
  setParentNames(arr[0].children);  
}  
  
console.log(arr);

若有多个顶级节点

// 假设 arr 包含多个顶级对象  
arr.forEach(topLevelNode => {  
  if (topLevelNode.children) {  
    // 将顶级节点的 name 作为子节点的 parentName 的根  
    setParentNames(topLevelNode.children, topLevelNode.name); 
  }  
}); 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值