時々、Smarty の構文解析の対象にしたくないと望む、 もしくはそうする必要がある部分があります。 典型的な例としては、 テンプレートに Javascript や CSS コードが含まれるときです。 それらの言語が Smarty のデフォルトの デリミタ である { と } を使用するときに問題が発生します。
もっとも単純な解決方法は、Javascript と CSS コードをそれぞれファイルに切り分け、 それらにアクセスするために標準的な HTML の機能を使用する事で状況を回避する事です。
リテラルコンテンツを含めるには
{literal}..{/literal}
ブロックを使用します。
HTML エンティティの使用法と同様に、 {ldelim}
、{rdelim}
あるいは
{$smarty.ldelim}
を使用して現在のデリミタを表示することができます。
単純に Smarty の
$left_delimiter
および
$right_delimiter
を変更するだけでも便利になることが多々あります。
Example 3.8. デリミタを変更する例
<?php $smarty->left_delimiter = '<!--{'; $smarty->right_delimiter = '}-->'; $smarty->assign('foo', 'bar'); $smarty->assign('name', 'Albert'); $smarty->display('example.tpl'); ?>
テンプレートはこのようになります。
Welcome <!--{$name}--> to Smarty <script language="javascript"> var foo = <!--{$foo}-->; function dosomething() { alert("foo is " + foo); } dosomething(); </script>