詳解PHP EasyTpl的功能及安裝使用方法

藏色散人
發布: 2023-04-10 19:52:01
轉載
3649 人瀏覽過

EasyTpl - 簡單快速的 PHP 範本引擎

#簡單快速的 PHP 範本引擎中。

功能特性

  • 簡單、輕量且快速。
    • 無學習成本
    • 只是簡單處理並轉換為原生PHP語法
    • 相容PHP原生語法使用
  • 更簡單的輸出語法。例如:{{= $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([
    &#39;tplDir&#39; => &#39;path/to/templates&#39;,
    &#39;allowExt&#39; => [&#39;.php&#39;, &#39;.tpl&#39;],]);// do something ...
登入後複製

#更多設定:

/** @var PhpPkg\EasyTpl\EasyTemplate $t */
$t->disableEchoFilter();
$t->addFilter($name, $filterFn);
$t->addFilters([]);
$t->addDirective($name, $handler);
登入後複製

輸出變數值

下面的語句一樣,都可以用來列印輸出變數值

{{ $name }}{{= $name }}{{ echo $name }}
登入後複製

更多:

{{ $name ?: &#39;inhere&#39; }}{{ $age > 20 ? &#39;20+&#39; : &#39;<= 20&#39; }}
登入後複製

預設會自動透過htmlspecialchars 將輸出結果處理,除非設定了停用或手動使用raw 過濾器

  • 設定停用輸出過濾$t->disableEchoFilter()
  • #模板中停用輸出過濾{{ $name | raw }}

#快速存取陣列值

可以使用 . 來快速存取陣列值。原來的寫法也是可用的,簡潔寫法也會自動轉換為原生寫法。

$arr = [
    &#39;val0&#39;,
    &#39;subKey&#39; => &#39;val1&#39;,];
登入後複製

在範本中使用:

first value is: {{ $arr.0 }} // val0&#39;subKey&#39; value is: {{ $arr.subKey }} // val1
登入後複製

If 語句區塊

if 語句:

{{ if ($name !== &#39;&#39;) }}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 }}
登入後複製

For/Foreach語句塊

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
  • #    -追加換行符\n

過濾器使用範例

您可以在任何範本中使用篩選器。

基本上使用:

{{ &#39;inhere&#39; | ucfirst }} // Inhere {{ &#39;inhere&#39; | upper }} // INHERE
登入後複製

鍊式使用:

{{ &#39;inhere&#39; | ucfirst | substr:0,2 }} // In{{ &#39;1999-12-31&#39; | date:&#39;Y/m/d&#39; }} // 1999/12/31
登入後複製

傳遞非靜態值:

{{ $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 }}
登入後複製

將變數作為過濾器參數傳遞:

{{
    $suffix = &#39;¥&#39;;}}{{ &#39;12.75&#39; | add_suffix:$suffix }} // 12.75¥
登入後複製

自訂過濾器

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);
    },]);
登入後複製

在模板中使用:

{{
  $name = &#39;inhere&#39;;}}{{ $name | upper }} // INHERE{{ $name | last3chars }} // ere{{ $name | last3chars | upper }} // ERE
登入後複製

自訂指令

您可以使用指令實作一些特殊的邏輯。

$tpl = EasyTemplate::new();$tpl->addDirective(
    &#39;include&#39;,
    function (string $body, string $name) {
        /** will call {@see EasyTemplate::include()} */
        return &#39;$this->&#39; . $name . $body;
    });
登入後複製

在模板中使用:

{{ include(&#39;part/header.tpl&#39;, [&#39;title&#39; => &#39;My world&#39;]) }}
登入後複製

Github: github.com/phppkg/easytpl

  推薦學習:《PHP影片教學》                            

以上是詳解PHP EasyTpl的功能及安裝使用方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
php
來源:learnku.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板