Heim > Datenbank > MySQL-Tutorial > Hauptteil

Wie erstellt man mit PHP und MySQL unbegrenzt viele Menüebenen: Eine Schritt-für-Schritt-Anleitung?

Barbara Streisand
Freigeben: 2024-10-30 18:57:03
Original
279 Leute haben es durchsucht

How to Build Unlimited Levels of Menus with PHP and MySQL: A Step-by-Step Guide?

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!