Maison  >  Article  >  développement back-end  >  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

藏色散人
藏色散人avant
2021-11-17 14:08:463632parcourir

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

快速开始

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;

渲染输出:

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+' : '74a3835a50559319c970010127e40c0ddisableEchoFilter()
  • 模板中禁用输出过滤 {{ $name | raw }}
  • 快速访问数组值

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

    $arr = [
        'val0',
        'subKey' => 'val1',];

    在模板中使用:

    first value is: {{ $arr.0 }} // val0'subKey' value is: {{ $arr.subKey }} // val1

    If 语句块

    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 1151b160bdcc90f86856a2d25abad689= 50) }}
     age >= 50.{{ elseif ($age >= 20) }}
     age >= 20.{{ else }}
     age 2df235674a603143fda7a375e75eecf1 $tag) }}{{ $index }}. {{ $tag }}{{ endforeach }}

    模板中添加注释

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

    {{# comments ... #}}{{ $name }} // inhere

    multi lines:

    {{# this
     comments
     block
    #}}{{ $name }} // inhere

    使用过滤器

    默认内置过滤器:

    • 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

    {{ 'inhere' | ucfirst }} // Inhere {{ 'inhere' | upper }} // INHERE

    Démarrage rapide

    {{ 'inhere' | ucfirst | substr:0,2 }} // In{{ '1999-12-31' | date:'Y/m/d' }} // 1999/12/31

    Sortie de rendu

     :
    {{ $name | ucfirst | substr:0,1 }}{{ $user['name'] | ucfirst | substr:0,1 }}{{ $userObj->name | ucfirst | substr:0,1 }}{{ $userObj->getName() | ucfirst | substr:0,1 }}

    🎜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 = '¥';}}{{ '12.75' | add_suffix:$suffix }} // 12.75¥
    🎜Plus de paramètres :🎜
    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);
        },]);
    🎜Valeur de la variable de sortie🎜🎜Les instructions suivantes peuvent être utilisées pour imprimer les valeurs des variables🎜
    {{
      $name = 'inhere';}}{{ $name | upper }} // INHERE{{ $name | last3chars }} // ere{{ $name | last3chars | upper }} // ERE
    🎜Plus :🎜
    $tpl = EasyTemplate::new();$tpl->addDirective(
        'include',
        function (string $body, string $name) {
            /** will call {@see EasyTemplate::include()} */
            return '$this->' . $name . $body;
        });
    🎜🎜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( )🎜🎜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('part/header.tpl', ['title' => 'My world']) }}
    🎜 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!

    Déclaration:
    Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer