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 z0i 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.

questionAnswers(2)

yourAnswerToTheQuestion