Maison > développement back-end > tutoriel php > Explication détaillée des fonctions et de l'installation et de l'utilisation de PHP EasyTpl

Explication détaillée des fonctions et de l'installation et de l'utilisation de PHP EasyTpl

藏色散人
Libérer: 2023-04-10 19:52:01
avant
3691 Les gens l'ont consulté

Moteur de modèles PHP simple et rapide.

Caractéristiques

Simple, léger et rapide.

Aucun coût d'apprentissage
  • Juste un traitement et une conversion simples vers la syntaxe PHP native
    • Compatible avec la syntaxe native PHP
    • Syntaxe de sortie plus simple. Par exemple : {{= $var }} {{ $var }} {{ echo $var }}
    prend en charge toutes les syntaxes de contrôle . Par exemple, if,elseif,else;foreach;for;switch
  • prend en charge l'accès chaîné aux valeurs du tableau. Par exemple : {{ $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 过滤器
  • 支持使用PHP内置函数作为过滤器。 例如:{{ $var | ucfirst }}
  • 支持添加自定义过滤器
    • 默认内置过滤器:upper lower nl
  • 支持添加自定义指令,提供自定义功能
  • 支持模板中添加注释。 例如: {{# comments ... #}}

安装

  • 需要 PHP 8.0+

composer

composer require phppkg/easytpl
Copier après la connexion

快速开始

use PhpPkg\EasyTpl\EasyTemplate;

$tplCode = <<<&#39;CODE&#39;
My name is {{ $name | strtoupper }},
My develop tags:

{{ foreach($tags as $tag) }}
- {{ $tag }}

{{ endforeach }}
CODE;

$t = new EasyTemplate();

$str = $t->renderString($tplCode, [
    &#39;name&#39; => &#39;inhere&#39;,
    &#39;tags&#39; => [&#39;php&#39;, &#39;go&#39;, &#39;java&#39;],
]);

echo $str;
Copier après la connexion

渲染输出:

My name is INHERE,My develop tags:- php- go- java
Copier après la connexion

更多使用说明

语法跟PHP原生模板一样的,加入的特殊语法只是为了让使用更加方便。

  • EasyTemplate 默认开启输出过滤,可用于渲染视图模板
  • TextTemplate 则是关闭了输出过滤,主要用于文本处理,代码生成等

配置设置

use PhpPkg\EasyTpl\EasyTemplate;$t = EasyTemplate::new([
    &#39;tplDir&#39; => &#39;path/to/templates&#39;,
    &#39;allowExt&#39; => [&#39;.php&#39;, &#39;.tpl&#39;],]);// do something ...
Copier après la connexion

更多设置:

/** @var PhpPkg\EasyTpl\EasyTemplate $t */
$t->disableEchoFilter();
$t->addFilter($name, $filterFn);
$t->addFilters([]);
$t->addDirective($name, $handler);
Copier après la connexion

输出变量值

下面的语句一样,都可以用于打印输出变量值

{{ $name }}{{= $name }}{{ echo $name }}
Copier après la connexion

更多:

{{ $name ?: &#39;inhere&#39; }}{{ $age > 20 ? &#39;20+&#39; : &#39;<= 20&#39; }}
Copier après la connexion

默认会自动通过 htmlspecialchars 将输出结果进行处理,除非设置了禁用或者手动使用 raw 过滤器

  • 设置禁用输出过滤 $t->disableEchoFilter()
  • 模板中禁用输出过滤 {{ $name | raw }}

快速访问数组值

可以使用 . 来快速访问数组值。原来的写法也是可用的,简洁写法也会自动转换为原生写法。

$arr = [
    &#39;val0&#39;,
    &#39;subKey&#39; => &#39;val1&#39;,];
Copier après la connexion

在模板中使用:

first value is: {{ $arr.0 }} // val0&#39;subKey&#39; value is: {{ $arr.subKey }} // val1
Copier après la connexion

If 语句块

if 语句:

{{ if ($name !== &#39;&#39;) }}hi, my name is {{ $name }}{{ endif }}
Copier après la connexion

if else 语句:

hi, my name is {{ $name }}age is {{ $age }}, and{{ if ($age >= 20) }}
 age >= 20.{{ else }}
 age < 20.{{ endif }}
Copier après la connexion

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 }}
Copier après la connexion

For/Foreach 语句块

foreach:

tags:{{ foreach($tags as $tag) }}- {{ $tag }}{{ endforeach }}
Copier après la connexion

with keys:

tags:{{ foreach($tags as $index => $tag) }}{{ $index }}. {{ $tag }}{{ endforeach }}
Copier après la connexion

模板中添加注释

{{##}} 包裹的内容将会当做注释忽略。

{{# comments ... #}}{{ $name }} // inhere
Copier après la connexion

multi lines:

{{# this
 comments
 block
#}}{{ $name }} // inhere
Copier après la connexion

使用过滤器

默认内置过滤器:

  • upper - 等同于 strtoupper
  • lower - 等同于 strtolower
  • nl - 追加换行符 n
  • Plus sécurisé, les résultats de sortie seront automatiquement traités via htmlspecialchars par défaut

Sauf s'il est désactivé ou si le filtre raw est utilisé manuellement

Prend en charge l'utilisation de PHP fonctions intégrées comme filtre. Par exemple : {{ $var | ucfirst }}

Prend en charge l'ajout de filtres personnalisésFiltre intégré par défaut : upper lower nl

Prend en charge l'ajout d'instructions personnalisées et la fourniture de fonctions personnalisées

Prend en charge l'ajout de commentaires aux modèles. Par exemple : {{# comments ... #}}

Installation

Nécessite PHP 8.0+

composer

{{ &#39;inhere&#39; | ucfirst }} // Inhere {{ &#39;inhere&#39; | upper }} // INHERE
Copier après la connexion

Démarrage rapide

{{ &#39;inhere&#39; | ucfirst | substr:0,2 }} // In{{ &#39;1999-12-31&#39; | date:&#39;Y/m/d&#39; }} // 1999/12/31
Copier après la connexion

Sortie de rendu

 :
{{ $name | ucfirst | substr:0,1 }}{{ $user[&#39;name&#39;] | ucfirst | substr:0,1 }}{{ $userObj->name | ucfirst | substr:0,1 }}{{ $userObj->getName() | ucfirst | substr:0,1 }}
Copier après la connexion

🎜Plus d'instructions d'utilisation🎜🎜La syntaxe est la même que celle du modèle natif PHP, la syntaxe spéciale est ajoutée juste pour la rendre plus pratique à utiliser. 🎜🎜🎜EasyTemplate active le filtrage de sortie par défaut et peut être utilisé pour afficher des modèles de vue 🎜🎜TextTemplate désactive le filtrage de sortie et est principalement utilisé pour le traitement de texte, la génération de code, etc. 🎜🎜🎜 🎜🎜Paramètres de configuration🎜
{{
    $suffix = &#39;¥&#39;;}}{{ &#39;12.75&#39; | add_suffix:$suffix }} // 12.75¥
Copier après la connexion
🎜Plus de paramètres :🎜
use PhpPkg\EasyTpl\EasyTemplate;$tpl = EasyTemplate::new();// use php built function$tpl->addFilter(&#39;upper&#39;, &#39;strtoupper&#39;);// 一次添加多个$tpl->addFilters([
    &#39;last3chars&#39; => function (string $str): string {
        return substr($str, -3);
    },]);
Copier après la connexion
🎜Valeur de la variable de sortie🎜🎜Les instructions suivantes peuvent être utilisées pour imprimer les valeurs des variables🎜
{{
  $name = &#39;inhere&#39;;}}{{ $name | upper }} // INHERE{{ $name | last3chars }} // ere{{ $name | last3chars | upper }} // ERE
Copier après la connexion
🎜Plus :🎜
$tpl = EasyTemplate::new();$tpl->addDirective(
    &#39;include&#39;,
    function (string $body, string $name) {
        /** will call {@see EasyTemplate::include()} */
        return &#39;$this->&#39; . $name . $body;
    });
Copier après la connexion
🎜🎜Par défaut, htmlspecialchars sera automatiquement transmis Les résultats de sortie seront traités à moins que le filtre brut ne soit désactivé ou utilisé manuellement 🎜
🎜🎜Défini pour désactiver le filtrage de sortie $t->disableEchoFilter( )< /code>🎜🎜Désactiver le filtrage de sortie dans les modèles <code>{{ $name | raw }}🎜🎜🎜🎜🎜Accéder rapidement aux valeurs du tableau🎜🎜Vous pouvez utiliser . pour accéder rapidement à la valeur des tableaux. La méthode d'écriture originale est également disponible et la méthode d'écriture concise sera automatiquement convertie en méthode d'écriture native. 🎜
{{ include(&#39;part/header.tpl&#39;, [&#39;title&#39; => &#39;My world&#39;]) }}
Copier après la connexion
🎜 Utilisé dans les modèles : 🎜rrreee🎜🎜🎜If bloc d'instructions 🎜🎜Instruction if : 🎜rrreee🎜if else instruction : 🎜rrreee🎜if . .elseif...else déclaration :🎜rrreee🎜🎜🎜For/Foreach bloc d'instructions🎜🎜foreach:🎜rrreee🎜avec clés :🎜rrreee🎜🎜🎜Ajouter des commentaires au modèle🎜 🎜Le contenu entouré de {{# et #}} sera ignoré en tant que commentaires. 🎜rrreee🎜lignes multiples :🎜rrreee🎜🎜🎜Utiliser des filtres🎜🎜Filtres intégrés par défaut :🎜🎜🎜upper - équivalent à strtoupper🎜🎜lower - Équivalent à <code>strtolower🎜🎜nl - Ajouter le caractère de nouvelle ligne n🎜🎜🎜🎜🎜Exemple d'utilisation de filtre🎜🎜Vous pouvez le trouver dans Utiliser des filtres dans n’importe quel modèle. "Utilisation de base" 🎜rr reee 🎜Utiliser dans modèles :🎜rrreee🎜🎜🎜Directives personnalisées🎜🎜Vous pouvez utiliser des directives pour implémenter une logique spéciale. 🎜rrreee🎜Utiliser dans le modèle : 🎜rrreee🎜🎜Github : github.com/phppkg/easytpl🎜

Apprentissage recommandé : "Tutoriel vidéo PHP"

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
php
source:learnku.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal