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 }} - 支持添加自定义过滤器
- 默认内置过滤器:
upperlowernl
- 默认内置过滤器:
- 支持添加自定义指令,提供自定义功能
- 支持模板中添加注释。 例如:
{{# comments ... #}}
安装
- 需要 PHP 8.0+
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 }} // val1If 语句块
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 }}For/Foreach 语句块
foreach:
tags:{{ foreach($tags as $tag) }}- {{ $tag }}{{ endforeach }}with keys:
tags:{{ foreach($tags as $index => $tag) }}{{ $index }}. {{ $tag }}{{ endforeach }}模板中添加注释
以 {{# 和 #}} 包裹的内容将会当做注释忽略。
{{# comments ... #}}{{ $name }} // inheremulti lines:
{{# this
comments
block
#}}{{ $name }} // inhere使用过滤器
默认内置过滤器:
upper- 等同于strtoupperlower- 等同于strtolowernl- 追加换行符\n
过滤器使用示例
您可以在任何模板中使用过滤器。
基本使用:
{{ 'inhere' | ucfirst }} // Inhere {{ 'inhere' | upper }} // INHERE链式使用:
{{ 'inhere' | ucfirst | substr:0,2 }} // In{{ '1999-12-31' | date:'Y/m/d' }} // 1999/12/31传递非静态值:
{{ $name | ucfirst | substr:0,1 }}{{ $user['name'] | ucfirst | substr:0,1 }}{{ $userObj->name | ucfirst | substr:0,1 }}{{ $userObj->getName() | ucfirst | substr:0,1 }}将变量作为过滤器参数传递:
{{
$suffix = '¥';}}{{ '12.75' | add_suffix:$suffix }} // 12.75¥自定义过滤器
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);
},]);在模板中使用:
{{
$name = 'inhere';}}{{ $name | upper }} // INHERE{{ $name | last3chars }} // ere{{ $name | last3chars | upper }} // ERE自定义指令
您可以使用指令实现一些特殊的逻辑。
$tpl = EasyTemplate::new();$tpl->addDirective(
'include',
function (string $body, string $name) {
/** will call {@see EasyTemplate::include()} */
return '$this->' . $name . $body;
});在模板中使用:
{{ include('part/header.tpl', ['title' => 'My world']) }}Github: github.com/phppkg/easytpl
相关阅读 更多
-
什么是因特网?它有什么作用?因特网的组成有哪些? 时间:2025-10-28 -
什么是因特网?什么是万维网?两者之间的区别是什么? 时间:2025-10-28 -
什么是局域网和广域网?两者之间的区别是什么? 时间:2025-10-28 -
什么是网络协议?常用的网络协议有哪些类型? 时间:2025-10-28 -
什么是网络协议? 它在网络中的作用是什么? 时间:2025-10-28 -
什么是网络协议?协议的三要素是什么?各有什么含义? 时间:2025-10-28
今日更新
-
2026年AI概念币投资指南 热门交易所权威推荐
阅读:18
-
十二星座是什么梗?揭秘星座爆笑名场面,一秒get你的专属笑点!
阅读:18
-
2026年十大热门Memecoin预测:DOGE、PEPE、WIF谁将登顶
阅读:18
-
"躺平摸鱼是什么梗?当代年轻人职场摆烂新姿势"
阅读:18
-
2026年去中心化AI代币TOP榜:FET与AGIX领衔未来趋势
阅读:18
-
2026年RWA代币TOP榜:ONDO、POLY、CFG领跑实物资产赛道
阅读:18
-
【SEO优化版】
"卷心菜兄是什么梗"揭秘网络热词背后打工人的自嘲式幽默,3秒get最新职场梗!
阅读:18
-
2026十大交易平台稳定性排名 币安欧易稳居榜首
阅读:18
-
王者荣耀十周年峡谷金曲玩家合唱版MV今日正式上线
阅读:18
-
2026全球最安全交易所排名 注册前必看权威指南
阅读:18










