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

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

Barbara Streisand
Barbara StreisandOriginal
2024-10-30 18:57:03349Durchsuche

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>

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!

Stellungnahme:
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