1 下载smarty3并将libs文件放在框架
libraries目录下重命名为smarty
2 在libraries下创建Ci_smarty.php文件,代码如下
<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');

require_once(APPPATH.'libraries/smarty/Smarty.class.php'); //这里指定Smarty.class.php的存放位置

class Ci_smarty extends Smarty
{
protected $ci;
public function __construct()
{
parent::__construct();
$this->ci = & get_instance();
$this->ci->load->config('smarty');//加载smarty的配置文件
$this->cache_lifetime =$this->ci->config->item('cache_lifetime');
$this->caching = $this->ci->config->item('caching');
$this->config_dir = $this->ci->config->item('config_dir');
$this->template_dir = $this->ci->config->item('template_dir');
$this->compile_dir = $this->ci->config->item('compile_dir');
$this->cache_dir = $this->ci->config->item('cache_dir');
$this->use_sub_dirs = $this->ci->config->item('use_sub_dirs');
$this->left_delimiter = $this->ci->config->item('left_delimiter');
$this->right_delimiter = $this->ci->config->item('right_delimiter');
}
}

3 在框架config目录下创建smarty.php,代码如下
<?php
$config['cache_lifetime'] = 3600;//缓存失效
$config['caching'] = true;//开启缓存
$config['template_dir'] = APPPATH .'views';
$config['compile_dir'] = APPPATH .'views/template_c';
$config['cache_dir'] = APPPATH . 'views/cache';
$config['config_dir'] = APPPATH . 'views/config';
$config['use_sub_dirs'] = false; //子目录变量(是否在缓存文件夹中生成子目录)
$config['left_delimiter'] = '{';
$config['right_delimiter'] = '}';
4 在配置文件autoload.php自动加载ci_smarty $autoload['libraries']=array('ci_smarty');
5 在框架的扩展父类MY_Controller.php(没有就现在core下创建)添加如下代码/ * @param $key * @par * smarty assign */
public function assign($key,$val)
{
$this->cismarty->assign($key,$val);
}

/**
* @param $html
* smarty smarty display方法
*/
public function display($html,$is_cache=false)
{
if(!$is_cache)
{
$this->ci_smarty->clearCache($html);
}
$this->ci_smarty->display($html);
}

/**
* smarty清除所有缓存
* @author shangshikai
*/
public function clearAllCache()
{
$this->ci_smarty->clearAllCache();
}

/**
* smarty 清除某个模板的缓存
* @author shangshikai
*/
public function clearCache($html)
{
$this->ci_smarty->clearCache($html);
}
/**
* @param $html
* @return mixed
* smarty判断该模板是否有缓存
*/
public function isCached($html)
{
return $this->ci_smarty->isCached($html);
}
6 由于在配置文件smarty.php中开启缓存,但不是所有页面都适合缓存,所以在MY_Controller中配置display方法时应增加参数默认清除缓存,需要缓存的页面只需在调用display方法时传递第二个参数为true。
在使用缓存后,如果需要局部不需要缓存可以使用{nocache}{/nocache}标签包裹,如果标签不缓存使用方法是在标签后增加nocache 如{foreach $arr as $v nocache}
7 如果整个项目都不使用缓存,可以在smarty.php中去掉$config['cache_lifetime'] = 3600;$config['caching'] = true;两行,并且在MY_Controller中的display方法去掉第二个
参数以及相关判断
内容来源于网络如有侵权请私信删除
你还没有登录,请先登录注册
  • 还没有人评论,欢迎说说您的想法!

相关课程

8628 0元 限免
3158 9.8元 100元 0.98折