javascript - 递归更新一个值到顶部的方法

标签 javascript

我正在尝试创建一个递归方法,当您单击一个层次结构时,所有父级都将被启用。

我知道如何使递归方法从上到下,例如,找到一个 child 的 id,但我不知道如何使递归方法从下到上。

例如:

const data =  [{
    "id": 1,
    "parentId": null,
    "selected": false,
    "children": [{
        "id": 2,
        "parentId": 1,
        "selected": false,
        "children": [{
            "id": 3,
            "parentId": 2,
            "selected": false,
            "children": [{
                "id": 4,
                "parentId": 3,
                "selected": false,
                "children": []
            }]
        }]
    }]
 }, {
    "id": 1,
    "parentId": null,
    "selected": true,
    "children": []
 }, {
    "id": 1,
    "parentId": null,
    "selected": true,
    "children": []
 }]

id 为 4 的项目被选中时,其所有祖先的 selected 属性应设置为 true

最佳答案

您可以简单地迭代直到当前节点的parentId变为null

const data = [{ id: 1, parentId: null, selected: false, children: [{id: 2, parentId: 1, selected: false, children: [{id: 3, parentId: 2, selected: false, children: [{id: 4, parentId: 3, selected: false, children: []}]} ]} ] }, { id: 5, parentId: null, selected: true, children: [] }, { id: 6, parentId: null, selected: true, children: [] } ];
const getById = id => {
  const get = arr => {
    for(const x of arr){
      if(x.id === id) return x;
      const res = get(x.children || []);
      if(res) return res;
    }
  }
  return get(data);
}
let node = getById(4);
while(node.parentId != null){
  node = getById(node.parentId);
  node.selected = true;
}
console.log(data);

关于javascript - 递归更新一个值到顶部的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63342176/

相关文章:

javascript - 通过ajax显示生成的图像

javascript - Google Meet 如何显示 CPU 使用率?

javascript - 如何通过多个条件过滤数组但保持其当前状态?

javascript - 使用 JavaScript 使用箭头键移动图像

javascript - 我的 Angular 路线在我在 app.js 中定义的实际 URL 之前有一个 '#%2F'

javascript:拆分字符串(但保留空格)

javascript - AngularUI Select2 ajax : Selection not updating ng-model

javascript - 将新函数带入闭包

javascript - JQuery AJAX 检索对象数组

javascript - Underscore.js中groupBy、filter、count怎么一起做?