Grav - Lebenszyklus
In diesem Kapitel werden wir den Lebenszyklus von Grav verstehen. Der Grav-Lebenszyklus bestimmt, wie Grav verarbeitet wird, um das Grav über Plugins zu erweitern. Das folgende Diagramm zeigt den Ablauf des Grav-Lebenszyklusprozesses.
Die folgenden vier Schritte aus dem Grav-Lebenszyklus -
PHP Version
Loader class is initialized
Obtain Grav Instance
Call Grav Process
PHP-Version
Es überprüft die Version von PHP, um sicherzustellen, dass wir die PHP-Version über 5.4.0 ausführen.
Die Loader-Klasse wird initialisiert
Im zweiten Schritt wird der Klassenlader initialisiert.
Besorgen Sie sich eine Grav-Instanz
Wenn keine Instanz vorhanden ist, ruft sie die load () -Methode auf und fügt Grav hinzu.
Es initialisiert den Debugger-Wert und fügt ihn dem Debugger hinzu.
Es registriert das Protokoll und den Fehlerbehandler.
Es fügt die URL, Aufgabe, Ereignisse, Cache, Sitzung, Plugins, Themen, Zweig, Taxonomie, Sprache, Seiten, Assets und Basis-URL hinzu.
Es registriert den Stream und den Konfigurationshandler.
Rufen Sie Grav Process auf
Es initialisiert die Konfiguration, das Uri-Objekt, den Fehlerhandler, den Debugger und die Sitzung.
Nach der Initialisierung wird die Ausgabe gepuffert.
Es initialisiert die Zeitzone und die Plugins und löst das Ereignis onPluginsInitialized aus .
Als Nächstes wird das Thema initialisiert und die Ereignisse onThemeInitialized und onTask [TASK] ausgelöst .
Es initialisiert die Assets und löst das Ereignis onAssetsInitialized aus .
Es initialisiert den Zweig mit den folgenden Aktionen:
Basierend auf der Konfiguration werden die Zweigvorlagenpfade festgelegt.
Behandelt die verfügbaren Sprachvorlagen.
Als nächstes wird das Ereignis onTwigTemplatePaths ausgelöst .
Die Konfiguration der Ladekette und des Zweigs wird geladen.
Fires onTwigInitialized Ereignis.
Es lädt die Zweigerweiterungen und löst das Ereignis onTwigExtensions aus .
Es legt die Standard-Zweigvariablen fest.
Als nächstes werden die Seiten initialisiert.
Es ruft die Methode buildPages () auf .
Wenn der Cache gut ist, werden Seiten aus dem Cache geladen. Wenn der Cache nicht gut ist, wird die Methode recurse () aufgerufen.
Das Ereignis onBuildPagesInitialized wird in der Methode recurse () ausgelöst .
Wenn eine Datei als .md gefunden wird , werden die folgenden Aktionen ausgeführt:
Um die Dateidetails zu laden, wird die Methode init () aufgerufen.
Es legt den Dateipfad, geändert und die ID fest.
Die header () -Methode wird aufgerufen, um Header-Variablen zu initialisieren.
Die slug () -Methode wird aufgerufen, um den URL-Slug festzulegen.
Die Methode visible () wird aufgerufen, um den sichtbaren Status festzulegen.
Basierend auf dem Ordner, der mit _ (Unterstrich) beginnt, wird modularTwig () festgelegt.
Später wird das Ereignis onPageProcessed ausgelöst .
recurse () die Kinder, wenn ein Ordner gefunden wird.
Es löst das Ereignis onFolderProcessed aus .
ruft die buildRoutes () -Methode auf.
Für alle Seiten wird die Taxonomie initialisiert
Die Route - Tabelle wird für schnelles Nachschlagen gebaut.
Die Ereignisse onPagesInitialized und onPageInitialized werden ausgelöst.
Debugger CSS / JS wird zu den Assets hinzugefügt.
Mit der processSite () -Methode von Twig erhalten wir die Ausgabe.
Das Ereignis onTwigSiteVariables wird ausgelöst.
Ruft die Ausgabe der Seite ab.
Wenn die Seite nicht gefunden oder nicht routingfähig ist, wird das Ereignis onPageNotFound ausgelöst.
Alle Twig-Variablen werden für das Twig-Objekt festgelegt.
Der Vorlagenname wird abhängig von den Datei- / Header- / Erweiterungsinformationen festgelegt.
Die Methode render () wird aufgerufen.
Gibt das Dateiformat in HTML zurück
Es löst das Ereignis onOutputGenerated aus .
Legen Sie die HTTP-Header fest.
Zeigt die Ausgabe an
Der Ausgabepuffer wird auf die Seite geleert.
Das Ereignis onOutputRendered wird ausgelöst .
Schließt die Verbindung zum Client.
Zuletzt wird das Ereignis onShutDown ausgelöst .
Wenn die content () -Methode auf Seite aufgerufen wird, tritt der folgende Lebenszyklus auf.
Das Ereignis onPageContentRaw wird ausgelöst .
Entsprechend den Markdown- und Twig-Einstellungen wird die Seite verarbeitet.
Es löst das Ereignis onPageContentProcessed aus .