smarty template engine
Thursday, January 08, 2009  
download | documentation | faq | forum | mailing lists | changelog | contribs 


search for in the  


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.

Esempio 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.

Esempio 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.




 

credits 

Smarty Copyright © 2002-2008
New Digital Group, Inc.

All rights reserved.