У меня есть небольшое приложение, которое выполняет следующее:
- позволяет пользователю загружать файл XML
- анализирует файл XML в массив для работы с $ _SESSION
- отображает список имен родительских элементов, которые пользователь может выбрать для просмотра
- анализирует массив для отображения дочерних элементов выбранных родительских элементов
Проблема заключается в том, что каждый item может иметь детей, которые могут иметь детей, которые могут иметь детей ... и т. д. ... и это может продолжаться бесконечно.
Как можно включить каждого ребенка ребенка вокончательный вывод?
XML-файлы могут выглядеть примерно так:
<thing>
<parents>
<parent>
<name>parent 1</name>
<categories>
<category>
<name>category 1</name>
<items>
<item>
<name>item 1 (gen 1)</name>
<items>
<item>
<name>sub-item 1 (gen 2)</name>
<items>
<item>
<name>sub-sub-item 1 (gen 3)</name>
...this could continue forever..
</item>
</items>
</item>
</items>
</item>
</items>
</category>
</categories>
</parent>
</parents>
</thing>
Я проанализировал XML в массив с помощью PHP SimpleXML.Каждый файл должен иметь родительский элемент, категорию и дочерние элементы первого поколения.Следующий код анализирует эти 3 уровня структуры, но за пределами этого я потерян.
$output .= '<ul>';
foreach($xml['parents'] as $parent){
$output .= '<li>'.$parent['name'].'</li>';
foreach($parent['categories']['category'] as $category){
$output .= '<li>'.$category['name'].'</li>';
foreach($category['items']['item'] as $item){
$output .= '<li>'.$item['name'].'</li>';
// here is where the $item can have children w/ children
// who can have children who can have children... etc... forever.
// (i.e. $item['items']['item'] as $generation2_items++...)
//
// I want to add them as another <li></li>...
//
// How can you account for unknown # of children?
}
}
}
$output .= '</ul>';
echo $output;
Код $ выводит список, подобный следующему:
- parent 1
-- category 1
--- item 1 (gen 1)
---- sub item 1 (gen 2)
----- sub-sub item 1 (gen 3)
------- etc.
-------- etc.
Как определитьсколько дочерних элементов вглубь каждого элемента, а затем, как вы можете создать достаточное количество циклов для соответствующего анализа ... или итерации другим способом?
Спасибо за вашу помощь.
Решение
Решена рекурсивная функция PHP.Вот что я использовал, когда добрался до возможной бесконечной повторяющейся части:
function foo($element, $indent=0){
$result .= '<li>';
if($indent > 0){
for($i=1;$i<=$indent;$i++){
$result .= ' ';
}
}
$result .= $element['name'].'</li>';
if(isset($element['children']['child'])){
$i++;
foreach($element['children']['child'] as $child){
$result .= foo($child, $i);
}
}
return $result;
}
$output .= foo($item);