집 >데이터 베이스 >MySQL 튜토리얼 >PHP와 MySQL에서 무제한의 깊이로 계층적 메뉴를 구축하는 방법은 무엇입니까?
깊이가 무제한인 계층적 메뉴 구축
이 가이드에서는 다음을 사용하여 레벨 수에 제한이 없는 중첩 메뉴를 만드는 방법을 살펴보겠습니다. PHP 및 MySQL.
데이터베이스 구조
각 메뉴 항목에 "id", "parent_id" 및 "title"이 있는 데이터베이스 구조를 사용하겠습니다. "parent_id" 필드는 메뉴 항목의 상위 항목 ID를 저장하며 "0"은 최상위 메뉴를 나타냅니다.
하위 메뉴 가져오기
상위 메뉴의 경우 다음 코드를 사용할 수 있습니다.
<code class="php"><?php $list = $obj->childmenu($parentid); foreach($list as $menu) { extract($menu); echo '<li><a href="#">'.$name.'</a></li>'; } ?></code>
하위 하위 메뉴 확인
메뉴에 하위 하위 메뉴가 있는지 확인하려면 위 코드를 수정하면 됩니다.
<code class="php"><?php $list = $obj->childmenu($parentid); foreach($list as $menu) { extract($menu); if (count($obj->childmenu($id)) > 0) { echo '<li><a href="#">'.$name.'</a><ul class="submenu">'; $list2 = $obj->childmenu($id); foreach($list2 as $menu2) { extract($menu2); echo '<li><a href="#">'.$name.'</a></li>'; } echo '</ul> </li>'; } else { echo '<li><a href="#">'.$name.'</a></li>'; } } ?></code>
이 코드는 중첩 루프를 사용하여 하위 메뉴를 가져오고 표시하여 계층 구조의 모든 수준이 캡처되도록 합니다. 결과는 메뉴 항목과 해당 하위 메뉴가 포함된 중첩된 HTML 구조가 됩니다.
위 내용은 PHP와 MySQL에서 무제한의 깊이로 계층적 메뉴를 구축하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!