详解PHP EasyTpl的功能及安装使用方法<span class="header-link octicon octicon-link"><span>Easy

详解PHP EasyTpl的功能及安装使用方法<span class="header-link octicon octicon-link"><span>Easy,第1张

概述详解PHP EasyTpl的功能及安装使用方法<span class="header-link octicon octicon-link"></span>EasyTpl - 简单快速的 PHP 模板引擎

EasyTpl - 简单快速的 PHP 模板引擎

简单快速的 PHP 模板引擎。

功能特性简单、轻量且快速。无学习成本仅仅简单处理并转换为原生PHP语法兼容PHP原生语法使用更加简单的输出语法。 例如:{{= $var }} {{ $var }} {{ echo $var }}支持所有控制语法。 例如 if,elseif,else;foreach;for;switch支持链式访问数组值。 例如:{{ $arr.0 }} {{ $map.@R_502_6889@ }} {{ $map.user.@R_502_6889@ }}更加安全,默认会自动通过 HTMLspecialchars 将输出结果进行处理除非设置了禁用或者手动使用 raw 过滤器支持使用PHP内置函数作为过滤器。 例如:{{ $var | ucfirst }}支持添加自定义过滤器默认内置过滤器:upper lower nl支持添加自定义指令,提供自定义功能支持模板中添加注释。 例如: {{# comments ... #}}安装需要 PHP 8.0+

composer

composer require PHPpkg/easytpl
快速开始
use PHPPkg\EasyTpl\EasyTemplate;$tplCode = <<<'CODE'My @R_502_6889@ is {{ $@R_502_6889@ | strtoupper }},My develop Tags:{{ foreach($Tags as $tag) }}- {{ $tag }}{{ endforeach }}CODE;$t = new EasyTemplate();$str = $t->renderString($tplCode, [    '@R_502_6889@' => 'inhere',    'Tags' => ['PHP', 'go', 'java'],]);echo $str;

渲染输出:

My @R_502_6889@ 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($@R_502_6889@, $filterFn);$t->addFilters([]);$t->addDirective($@R_502_6889@, $handler);
输出变量值

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

{{ $@R_502_6889@ }}{{= $@R_502_6889@ }}{{ echo $@R_502_6889@ }}

更多:

{{ $@R_502_6889@ ?: 'inhere' }}{{ $age > 20 ? '20+' : '<= 20' }}

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

设置禁用输出过滤 $t->disableEchoFilter()模板中禁用输出过滤 {{ $@R_502_6889@ | raw }}快速访问数组值

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

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

在模板中使用:

first value is: {{ $arr.0 }} // val0'subKey' value is: {{ $arr.subKey }} // val1
If 语句块

if 语句:

{{ if ($@R_502_6889@ !== '') }}hi, my @R_502_6889@ is {{ $@R_502_6889@ }}{{ endif }}

if else 语句:

hi, my @R_502_6889@ is {{ $@R_502_6889@ }}age is {{ $age }}, and{{ if ($age >= 20) }} age >= 20.{{ else }} age < 20.{{ endif }}

if...elseif...else 语句:

hi, my @R_502_6889@ is {{ $@R_502_6889@ }}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 ... #}}{{ $@R_502_6889@ }} // inhere

multi lines:

{{# this comments block#}}{{ $@R_502_6889@ }} // 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

传递非静态值:

{{ $@R_502_6889@ | ucfirst | substr:0,1 }}{{ $user['@R_502_6889@'] | ucfirst | substr:0,1 }}{{ $userObj->@R_502_6889@ | ucfirst | substr:0,1 }}{{ $userObj->get@R_502_6889@() | 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);    },]);

在模板中使用:

{{  $@R_502_6889@ = 'inhere';}}{{ $@R_502_6889@ | upper }} // INHERE{{ $@R_502_6889@ | last3chars }} // ere{{ $@R_502_6889@ | last3chars | upper }} // ERE
自定义指令

您可以使用指令实现一些特殊的逻辑。

$tpl = EasyTemplate::new();$tpl->addDirective(    'include',    function (string $body, string $@R_502_6889@) {        /** will call {@see EasyTemplate::include()} */        return '$this->' . $@R_502_6889@ . $body;    });

在模板中使用:

{{ include('part/header.tpl', ['Title' => 'My world']) }}

Github: github.com/PHPpkg/easytpl

推荐学习:《PHP视频教程》
总结

以上是内存溢出为你收集整理的详解PHP EasyTpl的功能及安装使用方法<span class="header-link octicon octicon-link"></span>EasyTpl - 简单快速的 PHP 模板引擎全部内容,希望文章能够帮你解决详解PHP EasyTpl的功能及安装使用方法<span class="header-link octicon octicon-link"></span>EasyTpl - 简单快速的 PHP 模板引擎所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1152358.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存