Laravel перебирает неограниченную иерархию древовидных без рекурсивного подхода - PullRequest
0 голосов
/ 07 июня 2018

Я реализовал печать дерева категорий на странице рекурсивно:

    foreach ($categories as $category) {
         $tree .='<li>'.$category->title.'';
         if(count($category->childs)) {
            $tree .=$this->childView($category);
        }
    }
    $tree .='<ul>';

    return view('categoryTreeview',compact('categories','allCategories','tree'));
}

public function childView($category){                 
        $html ='<ul>';
        foreach ($category->childs as $arr) {
            if(count($arr->childs)){
            $html .='<li>'.$arr->title.'';                  
                    $html.= $this->childView($arr);
                }else{
                    $html .='<li>'.$arr->title.'';                                 
                    $html .="</li>";
                }                   
        }

        $html .="</ul>";
        return $html;
}

Для структуры БД: id|title|parent_id Теперь мне нужно реализовать итеративный способ печати дерева категорий на странице, и такПока я не нашел решения.

Я также пытался:

 function buildTree($categories) {

    $childs = array();

    foreach($categories as $category)
        $childs[$category->parent_id][] = $category;

    foreach($categories as $category) if (isset($childs[$category->id]))
        $category->childs = $childs[$category->id];

     return $childs[0];
 }
$treez = buildTree($categories);

Но я также не знаю, как использовать эти данные не рекурсивно.

МожетКто-нибудь ведет меня по правильному пути?Может быть, мне следует объединить циклы foreach с каким-то условием while?

...