Funktionen
{{= $var }}
{{ $var }}
{{ echo $var }}
if,elseif,else;foreach;for;switch
{{ $arr.0 }}
{{ $map.name }}
{{ $map.user.name }}
{{= $var }}
{{ $var }}
{{ echo $var }}
if,elseif,else;foreach;for;switch
{{ $arr.0 }}
{{ $map.name }}
{{ $map.user.name }}
htmlspecialchars
将输出结果进行处理raw
过滤器{{ $var | ucfirst }}
upper
lower
nl
{{# comments ... #}}
composer
composer require phppkg/easytpl
use PhpPkg\EasyTpl\EasyTemplate; $tplCode = <<<'CODE' My name is {{ $name | strtoupper }}, My develop tags: {{ foreach($tags as $tag) }} - {{ $tag }} {{ endforeach }} CODE; $t = new EasyTemplate(); $str = $t->renderString($tplCode, [ 'name' => 'inhere', 'tags' => ['php', 'go', 'java'], ]); echo $str;
渲染输出:
My name is INHERE,My develop tags:- php- go- java
语法跟PHP原生模板一样的,加入的特殊语法只是为了让使用更加方便。
EasyTemplate
默认开启输出过滤,可用于渲染视图模板TextTemplate
则是关闭了输出过滤,主要用于文本处理,代码生成等use PhpPkg\EasyTpl\EasyTemplate;$t = EasyTemplate::new([ 'tplDir' => 'path/to/templates', 'allowExt' => ['.php', '.tpl'],]);// do something ...
更多设置:
/** @var PhpPkg\EasyTpl\EasyTemplate $t */ $t->disableEchoFilter(); $t->addFilter($name, $filterFn); $t->addFilters([]); $t->addDirective($name, $handler);
下面的语句一样,都可以用于打印输出变量值
{{ $name }}{{= $name }}{{ echo $name }}
更多:
{{ $name ?: 'inhere' }}{{ $age > 20 ? '20+' : '<= 20' }}
默认会自动通过
htmlspecialchars
将输出结果进行处理,除非设置了禁用或者手动使用raw
过滤器
$t->disableEchoFilter()
{{ $name | raw }}
可以使用 .
来快速访问数组值。原来的写法也是可用的,简洁写法也会自动转换为原生写法。
$arr = [ 'val0', 'subKey' => 'val1',];
在模板中使用:
first value is: {{ $arr.0 }} // val0'subKey' value is: {{ $arr.subKey }} // val1
if
语句:
{{ if ($name !== '') }}hi, my name is {{ $name }}{{ endif }}
if else
语句:
hi, my name is {{ $name }}age is {{ $age }}, and{{ if ($age >= 20) }} age >= 20.{{ else }} age < 20.{{ endif }}
if...elseif...else
语句:
hi, my name is {{ $name }}age is {{ $age }}, and{{ if ($age >= 50) }} age >= 50.{{ elseif ($age >= 20) }} age >= 20.{{ else }} age < 20.{{ endif }}
foreach
:
tags:{{ foreach($tags as $tag) }}- {{ $tag }}{{ endforeach }}
with keys:
tags:{{ foreach($tags as $index => $tag) }}{{ $index }}. {{ $tag }}{{ endforeach }}
以 {{#
和 #}}
包裹的内容将会当做注释忽略。
{{# comments ... #}}{{ $name }} // inhere
multi lines:
{{# this comments block #}}{{ $name }} // inhere
默认内置过滤器:
upper
- 等同于 strtoupper
lower
- 等同于 strtolower
nl
- 追加换行符 n
htmlspecialchars
verarbeitetraw
-Filter wird manuell verwendet. Unterstützt die Verwendung von PHP Integrierte Funktionen als Filter. Zum Beispiel: {{ $var |. ucfirst }}
Unterstützt das Hinzufügen benutzerdefinierter FilterStandardmäßiger integrierter Filter: upper
lower
nl
Unterstützt das Hinzufügen benutzerdefinierter Anweisungen und die Bereitstellung benutzerdefinierter Funktionen
Unterstützt das Hinzufügen von Kommentaren zu Vorlagen. Zum Beispiel: {{# comments ... #}}
Installation
composer
{{ 'inhere' | ucfirst }} // Inhere {{ 'inhere' | upper }} // INHERE
{{ 'inhere' | ucfirst | substr:0,2 }} // In{{ '1999-12-31' | date:'Y/m/d' }} // 1999/12/31
Rendering-Ausgabe
:🎜🎜Legen Sie fest, dass die Ausgabefilterung deaktiviert werden soll🎜Weitere Nutzungsanweisungen🎜🎜Die Syntax ist die gleiche wie bei der nativen PHP-Vorlage, die spezielle Syntax wurde nur hinzugefügt, um die Verwendung komfortabler zu gestalten. 🎜🎜🎜{{ $name | ucfirst | substr:0,1 }}{{ $user['name'] | ucfirst | substr:0,1 }}{{ $userObj->name | ucfirst | substr:0,1 }}{{ $userObj->getName() | ucfirst | substr:0,1 }}Nach dem Login kopierenEasyTemplate
aktiviert standardmäßig die Ausgabefilterung und kann zum Rendern von Ansichtsvorlagen verwendet werden. 🎜🎜TextTemplate
deaktiviert die Ausgabefilterung und wird hauptsächlich für die Textverarbeitung, Codegenerierung usw. verwendet. usw. 🎜🎜🎜 🎜🎜Konfigurationseinstellungen🎜🎜Weitere Einstellungen:🎜{{ $suffix = '¥';}}{{ '12.75' | add_suffix:$suffix }} // 12.75¥Nach dem Login kopieren🎜Variablenwert ausgeben🎜🎜Die folgenden Anweisungen können zum Ausdrucken von Variablenwerten verwendet werden🎜use PhpPkg\EasyTpl\EasyTemplate;$tpl = EasyTemplate::new();// use php built function$tpl->addFilter('upper', 'strtoupper');// 一次添加多个$tpl->addFilters([ 'last3chars' => function (string $str): string { return substr($str, -3); },]);Nach dem Login kopieren🎜Mehr:🎜{{ $name = 'inhere';}}{{ $name | upper }} // INHERE{{ $name | last3chars }} // ere{{ $name | last3chars | upper }} // ERENach dem Login kopieren🎜🎜Standardmäßig ist$tpl = EasyTemplate::new();$tpl->addDirective( 'include', function (string $body, string $name) { /** will call {@see EasyTemplate::include()} */ return '$this->' . $name . $body; });Nach dem Login kopierenhtmlspecialchar s wird automatisch übergeben
Die Ausgabeergebnisse werden verarbeitet, sofern sie nicht deaktiviert oder manuell verwendet werdenraw
Filter 🎜
$t->disableEchoFilter( )< /code>🎜🎜Ausgabefilterung in Vorlagen deaktivieren <code>{{ $name |. raw }}
🎜🎜🎜🎜🎜Schnell auf Array-Werte zugreifen🎜🎜Sie können .
verwenden, um Schneller Zugriff auf Array-Werte. Die ursprüngliche Schreibmethode ist ebenfalls verfügbar und die prägnante Schreibmethode wird automatisch in die native Schreibmethode konvertiert. 🎜{{ include('part/header.tpl', ['title' => 'My world']) }}
if
-Anweisung: 🎜rrreee🎜if else
-Anweisung: 🎜rrreee🎜if . .elseif...else
-Anweisung:🎜rrreee🎜🎜🎜For/Foreach-Anweisungsblock🎜🎜foreach
:🎜rrreee🎜mit Schlüsseln:🎜rrreee🎜🎜🎜Kommentare zur Vorlage hinzufügen🎜 🎜Inhalte, die mit {{#
und #}}
umschlossen sind, werden als Kommentare ignoriert. 🎜rrreee🎜mehrzeilig:🎜rrreee🎜🎜🎜Filter verwenden🎜🎜Standardmäßige integrierte Filter:🎜🎜🎜upper
– entspricht strtoupper
🎜🎜lower – Äquivalent zu <code>strtolower
🎜🎜nl
– Zeilenumbruchzeichen anhängen n
🎜🎜🎜🎜🎜Filterverwendungsbeispiel🎜🎜Sie können es finden in Verwenden Sie Filter in jeder Vorlage. 🎜🎜🎜Grundlegende Verwendung🎜:🎜rrreee🎜🎜Kettenverwendung🎜:🎜rrreee🎜🎜Nichtstatische Werte übergeben🎜:🎜rrreee🎜🎜Variablen als Filter übergeben. Parameter🎜:🎜rrreee🎜🎜🎜 Benutzerdefinierter Filter🎜rr reee 🎜Verwenden in Vorlagen:🎜rrreee🎜🎜🎜Benutzerdefinierte Direktiven🎜🎜Sie können Direktiven verwenden, um eine spezielle Logik zu implementieren. 🎜rrreee🎜In Vorlage verwenden: 🎜rrreee🎜🎜Github: github.com/phppkg/easytpl🎜Das obige ist der detaillierte Inhalt vonAusführliche Erläuterung der Funktionen sowie Installation und Nutzung von PHP EasyTpl. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!