У меня есть таблица menu
со столбцами: id
, value
, id_parent
.
В модели:
public function getMenu()
{
$sql = "SELECT * FROM menu";
return $this->db->query($sql);
}
В контроллере:
public function adminNavMenu()
{
$this->data['menu'] = $this->model->getMenu();
$result = [];
foreach ($this->data['menu'] as $key => $value) {
if ($value['id_parent'] == 0) {
$result[$value['id']] = $value;
} else {
$result[$value['id_parent']]['children'][] = $value;
}
}
}
Но учитываются только первые два уровня многоуровневого меню. Пытался применить цикл или рекурсию, но не могу ...
Помогите, пожалуйста, исправить ошибки.
Исходный вид меню:
Menu1
Menu2->
Menu2-1
Menu2-2
Menu2-3->
Menu2-3-1
Неверный вывод после var_dump($result)
;
Array
(
[1] => Array
(
[id] => 1
[value] => Menu1
[id_parent] => 0
)
[2] => Array
(
[id] => 2
[value] => Munu2
[id_parent] => 0
[children] => Array
(
[0] => Array
(
[id] => 3
[value] => Menu2-1
[id_parent] => 2
)
[1] => Array
(
[id] => 4
[value] => Menu2-2
[id_parent] => 2
)
[2] => Array
(
[id] => 5
[value] => Menu2-3
[id_parent] => 2
)
)
)
[5] => Array
(
[children] => Array
(
[0] => Array
(
[id] => 6
[value] => Menu2-3-1
[id_parent] => 5
)
)
)
)
Я публикую свой результат
Из приведенного ниже кода вы можете получить представление:
<?php
function get_menu_tree($parent_id)
{
global $con;
$menu = "";
$sqlquery = " SELECT * FROM menu where id_parent='" .$parent_id . "' "; // put your query
$res=mysqli_query($con,$sqlquery);
while($row=mysqli_fetch_array($res,MYSQLI_ASSOC))
{
$menu . = "<li>".$row['value']."</a>";
$menu .= "<ul>".get_menu_tree($row['id'])."</ul>"; //call recursively
$menu .= "</li>";
}
return $menu;
}
?>
Вызовите эту функцию:
<?php echo get_menu_tree(0);//start from root menus having parent id 0 ?>
Откуда status
?
опубликуйте свой результат, например, об ошибках и т. д.