Mettere in Cache l'output dei Plugin 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. Evitare che l'output di un plugin vada in cache 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 è: 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. Evitare che un intero blocco di template vada in cache 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 è: 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.