EasyTpl - シンプルで高速な PHP テンプレート エンジン
シンプルで高速な PHP テンプレート エンジン。
特徴
- シンプル、軽量、高速。
- 学習コストなし
- 単純な処理とネイティブ PHP 構文への変換
- PHP ネイティブ構文の使用と互換性がある
- 出力が簡単構文。例:
{{= $var }}
{{ $var }}
{{ echo $var }}
- すべてのコントロールをサポートします構文 。たとえば、
if,elseif,else;foreach;for;switch
- は、配列値への連鎖アクセスをサポートします。例:
{{ $arr.0 }}
{{ $map.name }}
{{ $map.user.name }}
- より安全なため、出力結果はデフォルトで
htmlspecialchars
によって自動的に処理されます。- 無効にするか手動で使用しない限り、
raw
filter
#PHP 組み込み関数をフィルターとして使用することをサポートします。例: - 無効にするか手動で使用しない限り、
- {{ $var | ucfirst }}
- デフォルトの組み込みフィルター:
- upper
カスタム命令の追加とカスタム関数の提供をサポート- upper
- テンプレートへのコメントの追加をサポートします。例:
- {{# コメント ... #}}
インストール
- 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+' : '<blockquote>デフォルトでは、出力結果は <p>htmlspecialchars を通じて自動的に処理されます<code> (ただし、</code>raw<code> フィルターを無効にするか手動で使用するように設定する場合を除く)</code></p> </blockquote>
- 出力フィルタリングを無効にするように設定する
- $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 <code></code>if...elseif...else ステートメント:<p></p><pre class="brush:php;toolbar:false">hi, my name is {{ $name }}age is {{ $age }}, and{{ if ($age >= 50) }} age >= 50.{{ elseif ($age >= 20) }} age >= 20.{{ else }} age <code></code>For/Foreach ステートメントブロック <h3> <span class="header-link octicon octicon-link"></span>foreach</h3>:<p></p><pre class="brush:php;toolbar:false">tags:{{ foreach($tags as $tag) }}- {{ $tag }}{{ endforeach }}
withkeys:
tags:{{ foreach($tags as $index => $tag) }}{{ $index }}. {{ $tag }}{{ endforeach }}コメント
をテンプレートに追加 {{
# および#}} パッケージの内容はコメントとして無視されます。
{{# comments ... #}}{{ $name }} // inhere
複数行:
{{# this comments block #}}{{ $name }} // inhereフィルターを使用
デフォルトの組み込みフィルター:
upper- -
- strtoupper
lower
と同等 - - strto lower
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']) }}
Github: github.com/phppkg/easytpl
以上がPHP EasyTplの機能とインストール・使い方を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

aphpDependencyInjectionContaineriSATOULTAINATINAGECLASSDEPTINCIES、強化測定性、テスト可能性、および維持可能性。

SELECT DEPENTENCINGINOFCENT(DI)大規模なアプリケーションの場合、ServicElocatorは小さなプロジェクトまたはプロトタイプに適しています。 1)DIは、コンストラクターインジェクションを通じてコードのテスト可能性とモジュール性を改善します。 2)ServiceLocatorは、センター登録を通じてサービスを取得します。これは便利ですが、コードカップリングの増加につながる可能性があります。

phpapplicationscanbeoptimizedforspeedandEfficiencyby:1)enabingopcacheinphp.ini、2)PreparedStatementswithpordatabasequeriesを使用して、3)LoopswithArray_filterandarray_mapfordataprocessing、4)の構成ngincasaSearverseproxy、5)

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl

tomakephpapplicationsfaster、followthesesteps:1)useopcodecachinglikeopcacheTostoredscriptbytecode.2)最小化abasequeriesecachingingindexing.3)leveragephp7機能forbettercodeefficiency.4)

依存性注入(DI)は、明示的に推移的な依存関係によりPHPコードのテスト可能性を大幅に改善します。 1)DI分離クラスと特定の実装により、テストとメンテナンスが柔軟になります。 2)3つのタイプのうち、コンストラクターは、状態を一貫性に保つために明示的な式依存性を注入します。 3)DIコンテナを使用して複雑な依存関係を管理し、コードの品質と開発効率を向上させます。

DatabaseQueryoptimizationInpholvesseveralstrategESTOEnhancePerformance.1)selectonlynlynlyndorycolumnStoredatedataTransfer.2)useindexingtospeedupdataretrieval.3)revenmecrycachingtostoreres sultsoffrequent queries.4)


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

メモ帳++7.3.1
使いやすく無料のコードエディター

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。
