Name
fetch
string fetch(string template,
string cache_id,
string compile_id);
Функция возвращает вывод шаблона вместо его отображения на экран. Укажите верный тип ресурса шаблонов и путь. В качестве необязательного второго параметра можно передать cache id. Смотрите раздел Кэширование для получения дополнительной информации.
В качестве необязательного третьего аргумента вы можете передать
$compile_id
.
Это полезно в случае, если вы хотите
скомпилировать несколько различных версий одного шаблона, например
несколько версий одного шаблона на разных языках.
Другое применение
$compile_id
можно найти,
если вы используете несколько
$template_dir
,
но только одну
$compile_dir
.
Устанавливайте свой compile_id
для каждой
$template_dir
,
иначе шаблоны с одинаковыми именами будут сохраняться поверх друг друга.
Также вы можете один раз указать
$compile_id
,
вместо того, чтобы каждый раз передавать его при вызове этой функции.
Example 13.14. fetch
<?php include("Smarty.class.php"); $smarty = new Smarty; $smarty->caching = true; // обращаемся к БД только если отсутствует кэш if(!$smarty->is_cached("index.tpl")) { // присваиваем некоторые значения $address = "245 N 50th"; $db_data = array( "City" => "Lincoln", "State" => "Nebraska", "Zip" = > "68502" ); $smarty->assign("Name","Fred"); $smarty->assign("Address",$address); $smarty->assign($db_data); } // перехватываем вывод $output = $smarty->fetch("index.tpl"); // здесь выполняем какие-либо действия с $output echo $output; ?>
См. также display() и template_exists.