Detaillierte Erklärung des View-Moduls von Laravel
Dieser Artikel führt Sie hauptsächlich in die relevanten Informationen zum View-Modul des Laravel-Lernprogramms ein. Es bietet einen gewissen Referenz-Lernwert für alle, die es benötigen Lassen Sie uns gemeinsam mit dem Herausgeber unten lernen.
Vorwort
Dieser Artikel führt Sie hauptsächlich in die relevanten Informationen zum View-Modul in Laravel ein und stellt sie Ihnen als Referenz und zum Studium zur Verfügung Folgende Worte Mehr gibt es nicht zu sagen, werfen wir einen Blick auf die ausführliche Einleitung.
Dieser Artikel basiert auf der Analyse und dem Schreiben des Routing-Modulcodes der Laravel 5.4-Version;
Dateistruktur
Ansicht Die Dateistruktur und Funktionen des Moduls sind in der folgenden Abbildung dargestellt:
Der ungefähre Prozess der visuellen Präsentation:
1, starten Sie das Rendern der Ansicht, indem Sie die Methode view() aufrufen
2 (1) Durchlaufen Sie den Pfad nacheinander. Wenn der Dateiname einen Namespace hat (d. h. den Teil vor ::), verwenden Sie das registrierte Pfadarray, das dem Namespace entspricht, andernfalls verwenden Sie das globale Pfadarray (Pfadvariable in der IlluminateViewFileViewFinder-Klasse). );
(2) Kombinieren Sie den aktuellen Pfad, den Dateinamen und den Suffixnamen (die Standardreihenfolge ist blade.php, php, css), um festzustellen, ob die Datei vorhanden ist
(3) Wenn die Datei nicht existiert, wird eine Ausnahme gemeldet: Die entsprechende Ansicht Die Datei existiert nicht, die entsprechende Engine wird zum Parsen gemäß dem Suffixnamen aufgerufen
5. Wenn es sich um ein Blade.php-Suffix handelt, verwenden Sie die Blade-Engine 🎜>Diese Engine übernimmt die Initiative zum Cachen. Wenn die Cache-Datei nicht abgelaufen ist, wird sie direkt aufgerufen und die Cache-Datei wird über sha1 (im Speicher/Framework/) generiert. Ansichtenverzeichnis (unten);
ob_start(); include $__path; ob_get_clean();
Die Blade-Engine kompiliert Dateien über eine große Anzahl regulärer Matching- und Replacement-Implementierung;
Während des Parsing-Prozesses verwendet Blade zunächst die Funktion token_get_all, um den HTML-Code (T_INLINE_HTML) in der Ansichtsdatei abzurufen, der berücksichtigt wird den PHP-Interpreter-Teil und führen Sie dann den regelmäßigen Austausch der Kommentare, Erweiterungen, Anweisungen und Echos-Teile nacheinander durch.
Kommentarteil
protected $compilers = [ 'Comments', // 注释部分 'Extensions', // 扩展部分 'Statements', // 语句块 (@ 开头的指令) 'Echos', // 输出 ]; protected function parseToken($token) { list($id, $content) = $token; if ($id == T_INLINE_HTML) { foreach ($this->compilers as $type) { $content = $this->{"compile{$type}"}($content); } } }
Erweiterungsteil
Fügen Sie über die Extend-Methode eine benutzerdefinierte Verarbeitungsrückruffunktion zu BladeCompiler hinzu und führen Sie einen benutzerdefinierten Textabgleich und eine benutzerdefinierte Textersetzung für den Vorlageninhalt durch.
preg_replace("/{{--(.*?)--}}/s", '', $value);
Anweisungsersetzung
Dieser Teil soll den Text der Anweisungen ersetzen, die kommen mit dem Framework wie @if und den durch die Direktivenmethode registrierten Anweisungen;
// 自定义的文本替换扩展 数组 protected $extensions = []; protected function compileExtensions($value) { foreach ($this->extensions as $compiler) { $value = call_user_func($compiler, $value, $this); } return $value; }
ViewCompilersConcernsCompilesAuthorizations: Berechtigungsprüfung
Zu den Befehlen gehören: @can, @cannot, @elsecan, @elsecannot, @endcan, @endcannot
ConcernsCompilesComponents: bezogen auf Komponenten und Slots
Zu den Anweisungen gehören: @component, @endcomponent, @slot, @endslot-
Zu den Anweisungen gehören: @if, @unless, @else, @elseif, @endif, @endunless, @isset, @endisset, @hassection
ConcernsCompilesConditionals: bezogen auf Urteilsaussagen -
Zu den Anweisungen gehören: @each, @include, @includeif, @includewhen
ConcernsCompilesIncludes: eingebettete Datei -
Zu den Befehlen gehören: @inject
ConcernsCompilesInjections: Service Injection -
Zu den Anweisungen gehören: @extends, @section, @parent, @yield, @show, @append, @overwrite, @stop, @endsection
ConcernsCompilesLayouts: bezogen auf das Layout -
Zu den Anweisungen gehören: @forelse, @empty, @endforelse, @endempty, @for, @foreach, @break, @continue, @endfor, @endforeach, @while, @endwhile
ConcernsCompilesLoops: bezogen auf Schleifen -
Zu den Befehlen gehören: @php, @endphp, @unset
BedenkenCompilesRawPhp: im Zusammenhang mit nativen PHP-Anweisungen -
Zu den Befehlen gehören: @stack, @push, @endpush, @prepend, @endprepend
ConcernsCompilesStacks: bezogen auf den Stack -
Zu den Anweisungen gehören: @lang, @endlang, @choice
ConcernsCompilesTranslations: im Zusammenhang mit der Lokalisierungsübersetzung -
Echo ersetzt
Echo-Ausgabe ist für {!!} , {{ }} für reguläre Ersetzung;
{!! !!} gibt nicht maskierte Zeichen aus, die zur Ausgabe nativer HTML-Tags-Werte verwendet werden;
{{ }} gibt normal aus und unterstützt die Ersetzung durch ternäre Operatoren.
{{ }}} gibt Escape-Zeichen aus und unterstützt die Ersetzung durch ternäre Operatoren 🎜>
Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung des View-Moduls von Laravel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Die Microservice-Architektur nutzt PHP-Frameworks (wie Symfony und Laravel) zur Implementierung von Microservices und folgt RESTful-Prinzipien und Standarddatenformaten zum Entwerfen von APIs. Microservices kommunizieren über Nachrichtenwarteschlangen, HTTP-Anfragen oder gRPC und nutzen Tools wie Prometheus und ELKStack zur Überwachung und Fehlerbehebung.

Für kleine Projekte eignet sich Laravel, für größere Projekte, die starke Funktionalität und Sicherheit erfordern. CodeIgniter eignet sich für sehr kleine Projekte, die geringes Gewicht und Benutzerfreundlichkeit erfordern.

Vergleichen Sie Laravel's Blade und die Twig-Vorlagen-Engine von CodeIgniter und wählen Sie je nach Projektanforderungen und persönlichen Vorlieben: Blade basiert auf der MVC-Syntax, die eine gute Codeorganisation und Vorlagenvererbung fördert. Twig ist eine Bibliothek eines Drittanbieters, die flexible Syntax, leistungsstarke Filter, erweiterten Support und eine Sicherheits-Sandbox bietet.
