What is Smarty?
Why use it?
Use Cases and Work Flow
Syntax Comparison
Template Inheritance
Best Practices
Crash Course
You may use the Smarty logo according to the trademark notice.
For sponsorship, advertising, news or other inquiries, contact us at:
A partire dai plugin di Smarty-2.6.0 la possibilità di mettere in
cache il loro output può essere dichiarata nel momento in cui li si
registrano. Il terzo parametro da passare a register_block,
register_compiler_function e register_function si chiama
$cacheable
e per default vale true, il che
equivale al comportamento dei plugin di Smarty nelle versioni
precedenti alla 2.6.0
Quando si registra un plugin con $cacheable=false il plugin viene chiamato tutte le volte che la pagina viene visualizzata, anche se la pagina stessa arriva dalla cache. La funzione del plugin funziona così un poco come una funzione insert.
Al contrario di ciò che avviene in {insert}, gli attributi passati
al plugin non vengono, per default, messi in cache. E' possibile però
dichiarare che devono essere messi in cache con il quarto parametro
$cache_attrs
. $cache_attrs
è un array di nomi di attributi che devono essere messi in cache, in
modo che la funzione del plugin ottenga il valore dell'attributo qual
era al momento in cui la pagina è stata salvata sulla cache ogni volta
che la cache stessa viene riletta.
Example 14.10. Evitare che l'output di un plugin vada in cache
<?php require('Smarty.class.php'); $smarty = new Smarty; $smarty->caching = true; function remaining_seconds($params, &$smarty) { $remain = $params['endtime'] - time(); if ($remain >=0) return $remain . " second(s)"; else return "done"; } $smarty->register_function('remaining', 'remaining_seconds', false, array('endtime')); if (!$smarty->is_cached('index.tpl')) { // leggiamo $obj dal db e lo assegnamo al template... $smarty->assign_by_ref('obj', $obj); } $smarty->display('index.tpl'); ?>
dove index.tpl è:
Time Remaining: {remain endtime=$obj->endtime}
Il numero di secondi che mancano alla scadenza di $obj cambia ad ogni visualizzazione della pagina, anche se questa è in cache. Siccome l'attributo endtime è in cache, l'oggetto deve essere letto dal database solo quando la pagina viene scritta sulla cache, ma non nelle richieste successive.
Example 14.11. Evitare che un intero blocco di template vada in cache
index.php: <?php require('Smarty.class.php'); $smarty = new Smarty; $smarty->caching = true; function smarty_block_dynamic($param, $content, &$smarty) { return $content; } $smarty->register_block('dynamic', 'smarty_block_dynamic', false); $smarty->display('index.tpl'); ?>
dove index.tpl è:
Page created: {"0"|date_format:"%D %H:%M:%S"} {dynamic} Now is: {"0"|date_format:"%D %H:%M:%S"} ... qui facciamo altre cose ... {/dynamic}
Quando ricaricate lapagina vedrete che le due date sono diverse. Una è "dinamica", l'altra è "statica". Potete mettere qualsiasi cosa fra {dynamic} e {/dynamic}, sicuri che non verrà messa in cache col resto della pagina.