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
Menu
-Klasse bietet Filterung und ermöglicht die bedingte Anzeige von Elementen basierend auf bestimmten Kriterien. Projektziele
Ziel ist es, Menüs effizient mit sauberem, professionellem, modernem objektorientiertem PHP-Code zu schaffen. Die gewünschte Funktionalität umfasst:
// 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');
semantisch Sub-Elemente ohne explizite übergeordnete IDs hinzufügen:
//... $about = $menu->add('About', 'about'); $about->add('Who we are?', 'who-we-are'); $about->add('What we do?', 'what-we-do'); //...
Hinzufügen von HTML -Attributen:
//... $menu->add('About', ['url' => 'about', 'class' => 'about-li active', 'id' => 'about-li']); //...
Anhängen oder Vorbereitung von Inhalten mit Links (z. B. Symbole):
//... $about = $menu->add('About', ['url' => 'about', 'class' => 'about-li active', 'id' => 'about-li']); $about->link->append('<b></b>') ->prepend(''); //...
Filterelemente:
$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; });
Menüs rendern als HTML (Listen, Divs usw.):
//... // Render as an unordered list echo $menu->asUl(); // Render as an ordered list echo $menu->asOl(); // Render as a div echo $menu->asDiv(); //...
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.
<?php class Menu { protected $menu = []; protected $reserved = ['pid', 'url']; // ... methods will be added here ... } ?>
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!