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 .