この記事では、主に PHP テンプレート エンジン Smarty カスタム変数メディエーターの使用方法とカスタム変数メディエーターの実装スキルを詳しく分析します。必要な方は、PHP で参照してください。 、テキストを処理するための関数が多数あり、その関数を通じて処理対象のテキストを処理し、Smarty テンプレート エンジンの assign() を呼び出して値を変数に割り当て、それを表示用のテンプレートに割り当てることができます。
Smarty の変数メディエーターは PHP のテキスト処理関数に似ていますが、Smarty では構文が異なり、パラメーターがある場合はその直後に「|」を介してメディエーター関数名を追加する必要があります。 「:」以降 後は、パラメータが複数ある場合はそれらを合計するだけです。
モデレータを定義するファイルはSmartyに配置する必要があります。具体的なパスは次のとおりです: libs/プラグイン/.ファイル名は Smarty modifier.mediatorname.php の形式である必要があります
以下は、例を通して Smarty でのカスタム変数メディエーターの使用を示しています
プログラムのアイデア: 2 つの変数メディエーターを作成します。関数は次のとおりです。傍受されたテキスト。
init.inc.php (Smarty初期化ファイル)
<?php define('ROOT_PATH', dirname(__FILE__)); //设置网站根目录 require ROOT_PATH.'/libs/Smarty.class.php'; //加载 Smarty 模板引擎 $_tpl = new Smarty(); //创建一个实例对象 $_tpl->template_dir = ROOT_PATH.'/tpl/'; //设置模板文件目录 $_tpl->compile_dir = ROOT_PATH.'./com/'; //设置编译文件目录 $_tpl->left_delimiter = '<{'; //设置左定界符 $_tpl->right_delimiter = '}>'; //设置右定界符 ?>
index.php (メインファイル)
<?php define('CONST_VAR', 'ABC'); require 'init.inc.php'; //引入模板初始化文件 global $_tpl; $_str = 'abcdEFGHigklmnOPQRSTuvwsYz'; //定义一个字符串 $_tpl->assign('str',$_str); //字符串赋值给str $_tpl->assign('str1',strtolower($_str)); //字符串全部转换为小写赋给str1 $_tpl->assign('str2',strtoupper($_str)); //字符串全部转换为大写赋给str2 $_tpl->assign('str3',ucfirst($_str)); //字符串首字母转换为大写赋给str3 $_tpl->assign('str4',substr($_str, 0,15).'...'); //截取字符串前15个字符,后面的用'...'代替,并赋给str4 $_tpl->assign('str5',strtoupper(substr($_str, 0,15)).'...'); //截取字符串前15个字符转换为大写,后面的用'...'代替,并赋给str4 $_tpl->display('index.tpl'); //引入模板 ?>
tpl/index.tpl
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Smarty 中的变量调解器</title> </head> <body> <{$str}><br /> <!-- 输出字符串原形 --> <{$str1}><br /> <!-- 输出字符串转换为小写--> <{$str2}><br /> <!-- 输出字符串转换为大写 --> <{$str3}><br /> <!-- 输出字符串首字母大写 --> <{$str4}><br /> <!-- 截取字符串,截取15个字符串,后面的用'...'代替 --> <{$str5}><br /> <!-- 截取字符串,截取15个字符串,转换为大写,后面的用'...'代替 --> <!-- 您会发现,使用赋值过来的变量,使用起来不是很灵活, 如果需要处理字符串,就必须得在主文件中设立一个新变量,并把值赋给这个新变量。 使用变量调解器,可灵活的处理字符串 --> <{$str|transform}><br /> <!-- 输出字符串原形--> <{$str|transform:"lower"}><br /> <!-- 输出字符串转换为小写--> <{$str|transform:"upper"}><br /> <!-- 输出字符串转换为大写 --> <{$str|transform:"firstdx"}><br /> <!-- 输出字符串首字母大写 --> <{$str|subString:0:15:"###"}><br /> <!-- 截取字符串,截取15个字符串,后面的用'###'代替 --> <{$str|subString:0:15:"@@@"|transform:"upper"}><br /> <!-- 截取字符串,截取15个字符串,后面的用'@@@'代替 --> <{$str|transform:"upper"|subString:0:15:"@@@"}><br /> <!-- 功能同上 --> </body> </html>
/libs/plug in s / modifier.transform.php (変換ファイル修飾子)
<?php /** * smarty_modifier_transform * 字符串转换的变量调解器函数 * @param string $string 处理字符串 * @param string $type 处理类型 */ function smarty_modifier_transform($string,$type) { switch ($type) { case 'upper' : $str = strtoupper($string); break; case 'lower' : $str = strtolower($string); break; case 'firstdx' : $str = ucfirst($string); break; default: $str = $string; } return $str; } ?>
lib/plugins/modifier.subString.php (インターセプトテキスト修飾子)
<?php /** * smarty_modifier_subString * 处理截取字符串调解器 * @param string $string 处理字符串 * @param int $start_num 开始位置,默认从头开始 * @param int $end_num 结束位置,默认20 * @param string $addTo 追加字符串,默认'...' */ function smarty_modifier_subString($string,$start_num=0,$end_num=20,$addTo='...') { $_str = ''; if (strlen(substr($string, $start_num, $end_num))>=$end_num) { $_str = substr($string, $start_num, $end_num).$addTo; } else { $_str = substr($string, $start_num, $end_num); } return $_str; } ?>
実行結果:
上記を経由この例では、作成したメディエーター関数を呼び出すことができるように、メディエーター ファイルを Smarty のプラグイン ディレクトリ plugins に配置する必要があり、命名は Smarty のルールに従う必要があることを示しています。もう 1 つの注意点は、定義された関数名は Smarty のデフォルトの命名規則 (例:smarty_modifier_XXX) にも準拠する必要があり、モディファイア ファイルには複数の関数ではなく 1 つの関数のみを含めることができるということです。
要約: 上記がこの記事の全内容です。皆様の学習に役立つことを願っています。
関連する推奨事項:
php の htmlentities() 関数の定義と使用法
php方法Androidクライアントを生成する端末のスキャンでログインできるQRコードの詳しい説明
以上がPHPテンプレートエンジンSmartyカスタム変数メディエーターの使用例と分析例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。