Я реализовал печать дерева категорий на странице рекурсивно:
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?