javascript - 检查 json 树是否没有更多的 child

标签 javascript json children delimited

我的问题与 Convert delimited string into hierarchical JSON with JQuery 有关

我有一个类似的任务,我必须从分隔字符串创建一个 json 对象,如下所示:

var input = ["Fred-Jim-Bob", "Fred-Jim", "Fred-Thomas-Rob", "Fred"];

哪些输出

[{
"name": "Fred",
"children": [{
    "name": "Jim",
    "children": [{
        "name": "Bob",
        "children": []
    }]
}, {
    "name": "Thomas",
    "children": [{
        "name": "Rob",
        "children": []
    }]
}]
}]

不同的是每个节点没有更多的 child 必须有一个名为“last”的附加子节点,如下所示:

{
    "name": "Thomas",
    "children": [{
        "name": "Rob",
        "children": [],
        "last":true

}

我能否使用此算法检测一个节点是否没有更多子节点并在那里添加一个额外的节点?

var input = ["Fred-Jim-Bob", "Fred-Jim", "Fred-Thomas-Rob", "Fred"];
var output = [];
for (var i = 0; i < input.length; i++) {
var chain = input[i].split("-");
var currentNode = output;
for (var j = 0; j < chain.length; j++) {
    var wantedNode = chain[j];
    var lastNode = currentNode;
    for (var k = 0; k < currentNode.length; k++) {
        if (currentNode[k].name == wantedNode) {
            currentNode = currentNode[k].children;
            break;
        }
    }
    // If we couldn't find an item in this list of children
    // that has the right name, create one:
    if (lastNode == currentNode) {
        var newNode = currentNode[k] = {name: wantedNode, children: []};
        currentNode = newNode.children;
    }
}
}

提前谢谢你。

最佳答案

如果您对输入列表进行了排序,您可以通过这种方式确定某些内容不再有子项:

  1. 假设您在“NodeA-NodeB-NodeC”。
  2. 如果您在列表中向右移动,则必须移动到字母表中靠后的位置,因此如果您移动到的列表项中没有“NodeA-NodeB”,那么 NodeB 就没有还有更多的 child 。

关于javascript - 检查 json 树是否没有更多的 child ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8813556/

相关文章:

json - 如何在golang中将从result(var)中获得的数据注入(inject)result1(var)

javascript - 我有一个应该是对象的数组

javascript - 全日历 + FancyBox2 : Passing and setting input value

ruby - 排序 JSON 值?

android - 使用 Android ComplexPreferences (JSON) 保存 Bundle

JavaScript - 在 Javascript 中获取 DOM 元素中包含的文本?

jquery - 隐藏一定范围的子项 jQuery

php - Symfony2 表单子(monad)项和错误

javascript - jquery ajax将变量从一个函数获取到另一个php

javascript - 创建滚动菜单 : rolling just once