Heim >Backend-Entwicklung >PHP-Tutorial >Dynamischer Menübauer für Bootstrap 3: Menümanager

Dynamischer Menübauer für Bootstrap 3: Menümanager

William Shakespeare
William ShakespeareOriginal
2025-02-21 10:26:09873Durchsuche

Dynamic Menu Builder for Bootstrap 3: Menu Manager

Bauen von Menüs und Navigationsstangen ist ein Kinderspiel mit Twitter -Bootstrap. Das Erstellen einer stilvollen Navigation ist mühelos. Obwohl ausreicht für viele Projekte, benötigen Sie möglicherweise eine feinere Kontrolle über Menüelemente und Links. Stellen Sie sich beispielsweise vor, Menüelemente aus einer Datenbank zu laden oder den Zugriff basierend auf den Benutzerberechtigungen einzuschränken. Statische Lösungen fallen hier ab; Ein dynamischer Ansatz ist erforderlich.

Dieses Tutorial zeigt einen dynamischen PHP -Menübauer. Es ist eine zweiteilige Serie. Teil eins deckt den Demo -Code und die Menu Klasse ab; Teil zwei wird andere Klassen und Verwendungsbeispiele beschreiben.

Schlüsselfunktionen

  • Dynamisches Menü Generierung: Menüs dynamisch in PHP erstellen, Elemente aus Datenbanken laden oder Benutzerberechtigungsprüfungen anwenden, die Einschränkungen der statischen Bootstrap -Navigation übertreffen.
  • benutzerfreundlich mit erweiterter Anpassung: Fügen Sie einfach Menüelemente und Unter-Elemente ohne komplexe ID-Verwaltung hinzu. Verbessern Sie die Verknüpfungen mit HTML -Attributen, Symbolen oder anderen Inhalten.
  • Filterung: Die Menu -Klasse bietet Filterung und ermöglicht die bedingte Anzeige von Elementen basierend auf bestimmten Kriterien.
  • Flexible HTML -Rendering: Render -Menüs als nicht ordnungsgemäße Listen, geordnete Listen oder Divs, die nahtlos in verschiedene Website -Layouts integriert werden.
  • umfassendes Menümanagement: separate Klassen verwalten Menüstruktur, Elemente und Links, jeweils Methoden zum Hinzufügen, Ändern und Rendern von Inhalten.

Projektziele

Ziel ist es, Menüs effizient mit sauberem, professionellem, modernem objektorientiertem PHP-Code zu schaffen. Die gewünschte Funktionalität umfasst:

<code class="language-php">// Create the menu
$menu = new Menu;

// Add items
$menu->add('Home', '');
$menu->add('About', 'about');
$menu->add('Services', 'services');
$menu->add('Portfolio', 'portfolio');
$menu->add('Contact', 'contact');</code>

semantisch Sub-Elemente ohne explizite übergeordnete IDs hinzufügen:

<code class="language-php">//...
$about = $menu->add('About', 'about');
    $about->add('Who we are?', 'who-we-are');
    $about->add('What we do?', 'what-we-do');
//...</code>

Hinzufügen von HTML -Attributen:

<code class="language-php">//...
$menu->add('About', ['url' => 'about', 'class' => 'about-li active', 'id' => 'about-li']);
//...</code>

Anhängen oder Vorbereitung von Inhalten mit Links (z. B. Symbole):

<code class="language-php">//...
$about = $menu->add('About', ['url' => 'about', 'class' => 'about-li active', 'id' => 'about-li']);
$about->link->append('<b></b>')
            ->prepend('');
//...</code>

Filterelemente:

<code class="language-php">$menu = new Menu;

$menu->add('Home', '');
$menu->add('About', 'about');
$menu->add('Services', 'services');
$menu->add('Portfolio', 'portfolio');
$menu->add('Contact', 'contact');

$menu->filter(function ($item) {
    if (/* statement */) {
        return true;
    }
    return false;
});</code>

Menüs rendern als HTML (Listen, Divs usw.):

<code class="language-php">//...
// Render as an unordered list
echo $menu->asUl();

// Render as an ordered list
echo $menu->asOl();

// Render as a div
echo $menu->asDiv();
//...</code>

Menü Builder -Struktur

Der Menübauer besteht aus drei Klassen:

  • Menu: Verwaltet Menüelemente (Erstellung, Änderung, Rendering).
  • Item: Menüelemente als Objekte darstellt (Titel, Link, Attribute, Daten).
  • Link: repräsentiert Links als Objekte.

Die Methoden für jede Klasse werden in den folgenden Abschnitten detailliert beschrieben.

Menüklasse (Menü.php)

<code class="language-php"><?php
class Menu {

    protected $menu = [];
    protected $reserved = ['pid', 'url'];

    // ... methods will be added here ...

}
?></code>

Das Attribut $menu enthält Item Objekte. $reserved enthält Tasten, die intern verwendet werden, und unterscheidet sie von HTML -Attributen.

(Der verbleibende Code für die Klassen Menu, Item und Link zusammen mit ihren Methoden würde hier enthalten, ähnlich wie die ursprünglichen Eingabe, jedoch möglicherweise mit geringfügigen Anpassungen für Klarheit und Stil Konsistenz.) Aufgrund der Länge des Codes wird hier weggelassen, aber die Struktur und Funktionalität würde der Beschreibung in der ursprünglichen Eingabeaufforderung folgen. Der Schlüssel besteht darin, den Code in überschaubare Stücke zu zerlegen und sich auf die Kernlogik jeder Methode zu konzentrieren. Die Helferfunktionen (getUrl, extractAttr, parseAttr) sind entscheidend für die Verwaltung der an die add übergebenen Optionen. Die Rendering -Methoden (asUl, asOl, asDiv) bieten Flexibilität bei der Ausgabe der Menüstruktur.

Das obige ist der detaillierte Inhalt vonDynamischer Menübauer für Bootstrap 3: Menümanager. 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