Heim >Backend-Entwicklung >PHP-Tutorial >Detaillierte Erklärung des View-Moduls von Laravel

Detaillierte Erklärung des View-Moduls von Laravel

巴扎黑
巴扎黑Original
2017-09-21 10:17:372844Durchsuche

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

3. Wenn es sich um ein CSS-Suffix handelt, wird die Datei-Engine verwendet und die Kernaufrufmethode ist file_get_contents;


4. Wenn es sich um ein PHP-Suffix handelt, verwenden Sie php Die Kernaufrufmethode ist



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();
Blade-Engine-Kompilierung



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


Der Kerncode ist Ersetzen Sie wie folgt das Kommentarsymbol „{{ -- --}}“. Der umschlossene Code wird durch eine leere Zeichenfolge ersetzt:
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.

Der Kerncode befindet sich in der IlluminateViewBladeCompiler-Datei , wie folgt:
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;

Die vom Framework bereitgestellten Anweisungen bestehen aus den folgenden zehn Teilen:
// 自定义的文本替换扩展 数组
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

  • ConcernsCompilesConditionals: bezogen auf Urteilsaussagen

    Zu den Anweisungen gehören: @if, @unless, @else, @elseif, @endif, @endunless, @isset, @endisset, @hassection

  • ConcernsCompilesIncludes: eingebettete Datei

    Zu den Anweisungen gehören: @each, @include, @includeif, @includewhen

  • ConcernsCompilesInjections: Service Injection

    Zu den Befehlen gehören: @inject

  • ConcernsCompilesLayouts: bezogen auf das Layout

    Zu den Anweisungen gehören: @extends, @section, @parent, @yield, @show, @append, @overwrite, @stop, @endsection

  • ConcernsCompilesLoops: bezogen auf Schleifen

    Zu den Anweisungen gehören: @forelse, @empty, @endforelse, @endempty, @for, @foreach, @break, @continue, @endfor, @endforeach, @while, @endwhile

  • BedenkenCompilesRawPhp: im Zusammenhang mit nativen PHP-Anweisungen

    Zu den Befehlen gehören: @php, @endphp, @unset

  • ConcernsCompilesStacks: bezogen auf den Stack

    Zu den Befehlen gehören: @stack, @push, @endpush, @prepend, @endprepend

  • ConcernsCompilesTranslations: im Zusammenhang mit der Lokalisierungsübersetzung

    Zu den Anweisungen gehören: @lang, @endlang, @choice

  • 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 🎜>

  • Ersetzung durch ternäre Operatoren bezieht sich auf: {{ $a ?: „Standardwert“ }} (oder {{$a oder „Standardwert“}}) Ersetzung wird zu {{ isset($ a) ? $a : „Standardwert“}}

    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!

    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