详解PHP EasyTpl的功能及安装使用方法
时间:2022-02-23 17:11
简单快速的 PHP 模板引擎。 composer 渲染输出: 语法跟PHP原生模板一样的,加入的特殊语法只是为了让使用更加方便。 更多设置: 下面的语句一样,都可以用于打印输出变量值 更多: 默认会自动通过 可以使用 在模板中使用: with keys: 以 multi lines: 默认内置过滤器: 您可以在任何模板中使用过滤器。 基本使用: 链式使用: 传递非静态值: 将变量作为过滤器参数传递: 在模板中使用: 您可以使用指令实现一些特殊的逻辑。 在模板中使用: Github: github.com/phppkg/easytpl 以上就是详解PHP EasyTpl的功能及安装使用方法的详细内容,更多请关注www.gxlsystem.com其它相关文章!EasyTpl - 简单快速的 PHP 模板引擎
功能特性
{{= $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 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
更多使用说明
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
语句:{{ 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 }}
tags:{{ foreach($tags as $index => $tag) }}{{ $index }}. {{ $tag }}{{ endforeach }}
模板中添加注释
{{#
和 #}}
包裹的内容将会当做注释忽略。{{# comments ... #}}{{ $name }} // inhere
{{# this
comments
block
#}}{{ $name }} // inhere
使用过滤器
upper
- 等同于 strtoupper
lower
- 等同于 strtolower
nl
- 追加换行符 \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']) }}