Funkcja rekurencyjna do sortowania węzłów nadrzędnych i podrzędnych w PHP za pomocą pętli foreach na tablicy
Mam zestaw danych przechowywany w tablicy, która odwołuje się do identyfikatorów rodzica-dziecka:id
, parent_id
, title
itd. Najwyższy poziom maparent_id
z0
i mogą istnieć niezliczone relacje rodzic-dziecko.
Więc sortuję tę tablicę za pomocąforeach
zapętlić funkcję rekurencyjną, aby sprawdzić każdy element tablicy względem elementu macierzystego, i myślę, że zbyt długo wpatrywałem się w tę metodę.
Skończę z elementami w poprawnej kolejności, ale nie mogę poprawnie zagnieżdżać list, co sprawia, że myślę, że metoda nie działa.
Czy to najlepsza droga do pokonania?Co mogę zrobić, aby poprawić i naprawić tę metodęCzy jest jeszcze jedna sztuczka, którą mogę zastosować?Oto moje źródło:
<div>
<div>Subpages</div>
<ul>
<?php subPages($this->subpages->toArray(), 0) ?>
</ul>
<br>
<a href="javascript:;" onclick="">Add New Subpage</a>
</div>
<?php
function subPages($subpages, $parent){
foreach($subpages as $key => &$page){
$newParent = $page['id'];
//If the current page is the parrent start a new list
if($page['id'] == $parent)
{
//Echo out a new list
echo '<ul>';
echo '<li class="collapsed">';
echo '<a href="javascript:;" class="toggle">+</a>';
echo '<a href="javascript:;" onclick="">'.$page['title'].'</a>';
subPages($subpages, $newParent);
echo '</li>';
echo '</ul>';
}
//If the page's parent id matches the parent provided
else if($page['parent_id'] == $parent)
{
//Echo out the link
echo '<li class="collapsed">';
echo '<a href="javascript:;" class="toggle">+</a>';
echo '<a href="javascript:;" onclick="">'.$page['title'].'</a>';
//Set the page as the new parent
$newParent = $page['id'];
//Remove page from array
unset($subpages[$key]);
//Check the rest of the array for children
subPages($subpages, $newParent);
echo '</li>';
}
}
}
?>
Jak zawsze docenia się wszelką pomoc. Daj mi znać, jeśli coś nie jest jasne.