Unbegrenzte Menüebenen mit PHP und MySQL erstellen
Bei der Website-Entwicklung spielt die Menünavigation eine entscheidende Rolle für die Benutzererfahrung. Allerdings kann die Erstellung von Menüs, die eine unbegrenzte Anzahl von Untermenüs unterstützen, eine Herausforderung sein. Lassen Sie uns einen umfassenden Ansatz untersuchen, um diese Funktionalität mithilfe von PHP und MySQL zu erreichen.
Datenbankstruktur und Menüsystem
Die von Ihnen erwähnte Datenbankstruktur ist ein gängiger Ansatz zur Darstellung von a hierarchisches Menüsystem. Jeder Menüpunkt verfügt über ein übergeordnetes Feld, um die Eltern-Kind-Beziehung herzustellen. Die übergeordnete ID 0 gibt Menüelemente der obersten Ebene an.
Menüs der obersten Ebene abrufen
Ihr vorhandener PHP-Code zum Abrufen von Menüs der obersten Ebene ist korrekt:
<code class="php">$list = $obj->childmenu($parentid); foreach($list as $menu) { echo '<li><a href="#">'.$name.'</a></li>'; }</code>
Vorhandensein und Anzeige von Untermenüs identifizieren
Ihre Abfrage zielt darauf ab, zu ermitteln, ob ein Menüelement untergeordnete Menüs hat, und diese innerhalb seines Listenelements anzuzeigen. Um dies zu erreichen, müssen Sie Ihre SQL-Abfrage und Ihren PHP-Code ändern.
Optimierte SQL-Abfrage
Mit einer einzigen SQL-Abfrage können wir alle Menüpunkte sortiert nach abrufen ihre übergeordnete ID und Position:
<code class="sql">SELECT id, parent_id, title, link, position FROM menu_item ORDER BY parent_id, position;</code>
Verfeinerter PHP-Code
Der überarbeitete PHP-Code enthält einen Stapel zur Verfolgung der aktuellen Menüebene und gewährleistet eine effiziente Handhabung verschachtelter Menüs :
<code class="php">$items = $query_results; // Assuming $query_results contains the result of the SQL query $html = ''; $parent = 0; $parent_stack = array(); foreach ( $items as $item ) { if ( !empty($item['parent_id']) ) { $children[$item['parent_id']][] = $item; } } while ( ( $option = each( $children[$parent] ) ) || ( $parent > 0 ) ) { if ( !empty( $option ) ) { if ( !empty( $children[$option['value']['id']] ) ) { $html .= '<li>' . $option['value']['title'] . '<ul>'; array_push( $parent_stack, $parent ); $parent = $option['value']['id']; } else { $html .= '<li>' . $option['value']['title'] . '</li>'; } } else { $html .= '</ul>'; $parent = array_pop( $parent_stack ); } } echo $html;</code>
Dieser aktualisierte Code verarbeitet effektiv die Menüstruktur, erstellt HTML-Markup für verschachtelte Menüs und zeigt sie in ihren jeweiligen Listenelementen an.
Das obige ist der detaillierte Inhalt vonWie erstellt man mit PHP und MySQL unbegrenzt viele Menüebenen: Eine Schritt-für-Schritt-Anleitung?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!