| $smarty->cache-dir="目录名"; //创建缓存目录名$smarty->caching=true; //开启缓存,为false的时候缓存无效$smarty->cache_lifetime=60; //缓存时间,单位是秒
 二、Smarty缓存的使用与清除
  $marty->display("cache.tpl",cache_id); //创建带ID的缓存$marty->clear_all_cache(); //清楚所有缓存$marty->clear_cache("index.php"); //清楚index.php中的缓存$marty->clear_cache("index.php',cache_id); //清楚index.php中指定ID的缓存
 三、Smarty的局部缓存
第一个: insert_函数默认是不缓存,这个属性是不能修改
使用方法:例子
index.php中,
  function insert_get_time(){return date("Y-m-d H:m:s");} 
 index.html中,
  {insert name="get_time"}
 第二个: smarty_block
定义一个block:smarty_block_name($params,$content, &$smarty){return $content;} //name表示区域名
注册block:$smarty->register_block('name', 'smarty_block_name', false); //第三参数false表示该区域不被缓存
模板写法:{name}内容{/name}
写成block插件:
1)定义一件插件函数:block.cacheless.php,放在smarty的plugins目录
block.cacheless.php的内容如下:
  function smarty_block_cacheless($param, $content, &$smarty) {return $content;}?> 
 2) 编写程序及模板
示例程序:testCacheLess.php
  include('Smarty.class.php');$smarty = new Smarty;$smarty->caching=true;$smarty->cache_lifetime = 6;$smarty->display('cache.tpl');?> 
 所用的模板:cache.tpl
已经缓存的:{$smarty.now}{cacheless}
没有缓存的:{$smarty.now}
{/cacheless}
四、自定义缓存
设置cache_handler_func使用自定义的函数处理缓存
如:
 $smarty->cache_handler_func = "myCache";function myCache($action, &$smarty_obj, &$cache_content, $tpl_file=null, $cache_id=null, $compile_id=null){} 
 该函数的一般是根椐$action来判断缓存当前操作:
  switch($action){case "read"://读取缓存内容case "write"://写入缓存case "clear"://清空} 
 一般使用md5($tpl_file.$cache_id.$compile_id)作为唯一的cache_id
如果需要,可使用gzcompress和gzuncompress来压缩和解压。 |