【发布时间】:2019-05-06 17:51:26
【问题描述】:
我正在开发一个内容管理系统,但在 CMS 中遇到了菜单的父子关系问题。
基本上我有一个可以创建菜单和子菜单的系统。这是数据库中的数组的样子。
array:6 [
0 => array:4 [
"id" => 4
"name" => "Contacts"
"order" => 0
"parent_menu_id" => null
]
1 => array:4 [
"id" => 1
"name" => "Leads"
"order" => 1
"parent_menu_id" => null
]
2 => array:4 [
"id" => 2
"name" => "List Leads"
"slug" => "list-leads"
"order" => 1
"parent_menu_id" => 1
]
3 => array:4 [
"id" => 5
"name" => "Edit Leads"
"slug" => "edit-leads"
"order" => 1
"parent_menu_id" => 1
]
4 => array:4 [
"id" => 3
"name" => "Create New"
"slug" => "new"
"order" => 2
"parent_menu_id" => 2
]
5 => array:4 [
"id" => 14
"name" => "Tasks"
"slug" => "tasks"
"order" => 3
"parent_menu_id" => null
]
]
我正在使用菜单表中的父 ID 插入菜单和子菜单。如上所述,我正在从 db 中获取菜单。那么,如何以树状结构的层次形式生成/呈现菜单?
我需要遍历一个可以有任意数量导航的数组,并智能地将其排序到它的父子关系中。我能够做到,但只有一层深。它需要管理具有无限层数的子与子等,并将其输出到 HTML 下拉菜单和下拉项嵌套列表。
我正在创建一个函数,它只显示父母和它的孩子,但不显示任何孩子的孩子。我该如何解决?
public static function render_module_menu() {
$menus = MenusModel::leftJoin('modules', 'menus.module_id', '=', 'modules.id')->where('modules.enable', 1)->select('menus.*')->orderBy('order')->get()->toArray();
foreach ($menus as $menu) {
$childMenus = MenusModel::where('parent_menu_id', $menu['id'])->orderBy('order')->get()->toArray();
if ($childMenus) {
echo '<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="pagesDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
<i class="'.$menu['icon'].'"></i>
<span>'.$menu['name'].'</span>
</a>
<div class="dropdown-menu" aria-labelledby="pagesDropdown">';
foreach ($childMenus as $child) {
echo '<a class="dropdown-item" href="'.url($menu['slug'].'/'.$child['slug']).'">
<i class="'.$child['icon'].'" style="margin-right: 10px;"></i>
'.$child['name'].'</a>';
}
echo '</div>
</li>';
} else {
echo '<li class="nav-item">
<a class="nav-link" href="'.url($menu['slug']).'">
<i class="'.$menu['icon'].'"></i>
<span>'.$menu['name'].'</span></a>
</li>';
}
}
}
【问题讨论】: