мой вопрос относится к Convert delimited string into hierarchical JSON with JQueryПроверьте дерево JSON не иметь больше детей
У меня есть похожая задача, где я должен создать объект 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": []
}]
}]
}]
с той разницей, что каждый узел, который не имеет больше детей должен иметь дополнительный вспомогательный узел, называемый «последним», как это:
{
"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;
}
}
}
Заранее спасибо.
Я просто кратко посмотрел на это, но разве вы не могли просто запустить его против кучи входов, чтобы проверить, правильно ли он обрабатывает все случаи? Это выглядит с первого взгляда, но нет никакой замены для жестких доказательств. – Milimetric
+1 для приятного написанного 1-го сообщения –
@ Милиметрический: да, он правильно его обрабатывает, я уже тестировал 8000 узлов - пока все хорошо. Я просто хочу найти листья без детей и как-то помарчить. – mvovchak