Integration steps of smarty3 under CI framework (with code)

不言
Release: 2023-04-04 08:48:01
forward
1631 people have browsed it

The content of this article is about the integration steps of smarty3 under the CI framework (with code). It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.

1 Download smarty3 and place the libs file in the framework libraries directory and rename it to smarty
2 Create the Ci_smarty.php file under the libraries, the code is as follows

<?php  
if ( ! defined(&#39;BASEPATH&#39;)) exit(&#39;No direct script access allowed&#39;);

require_once(APPPATH.&#39;libraries/smarty/Smarty.class.php&#39;);     //这里指定Smarty.class.php的存放位置
class Ci_smarty extends Smarty
{
    protected $ci;
    public function __construct()
    {
        parent::__construct();
        $this->ci = & get_instance();
        $this->ci->load->config(&#39;smarty&#39;);//加载smarty的配置文件
        $this->cache_lifetime =$this->ci->config->item(&#39;cache_lifetime&#39;);
        $this->caching = $this->ci->config->item(&#39;caching&#39;);
        $this->config_dir = $this->ci->config->item(&#39;config_dir&#39;);
        $this->template_dir = $this->ci->config->item(&#39;template_dir&#39;);
        $this->compile_dir = $this->ci->config->item(&#39;compile_dir&#39;);
        $this->cache_dir = $this->ci->config->item(&#39;cache_dir&#39;);
        $this->use_sub_dirs = $this->ci->config->item(&#39;use_sub_dirs&#39;);
        $this->left_delimiter = $this->ci->config->item(&#39;left_delimiter&#39;);
        $this->right_delimiter = $this->ci->config->item(&#39;right_delimiter&#39;);
    }
}
Copy after login

3 In Create smarty.php in the framework config directory, the code is as follows

<?php
$config[&#39;cache_lifetime&#39;] = 3600;//缓存失效
$config[&#39;caching&#39;] = true;//开启缓存
$config[&#39;template_dir&#39;] = APPPATH .&#39;views&#39;;
$config[&#39;compile_dir&#39;] = APPPATH .&#39;views/template_c&#39;;
$config[&#39;cache_dir&#39;] = APPPATH . &#39;views/cache&#39;;
$config[&#39;config_dir&#39;] = APPPATH . &#39;views/config&#39;;
$config[&#39;use_sub_dirs&#39;] = false; //子目录变量(是否在缓存文件夹中生成子目录)
$config[&#39;left_delimiter&#39;] = &#39;{&#39;;
$config[&#39;right_delimiter&#39;] = &#39;}&#39;;
Copy after login

4 Automatically load ci_smarty

$autoload[&#39;libraries&#39;]=array(&#39;ci_smarty&#39;);
Copy after login

5 in the configuration file autoload.php in the extended parent class MY_Controller.php of the framework (if not, just core now Created below) Add the following code

/ * @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);
  }
Copy after login
/**
 * @param $html
 * @return mixed
 * smarty判断该模板是否有缓存
 */
public function isCached($html)
{
    return $this->ci_smarty->isCached($html);
}
Copy after login

6 Since caching is enabled in the configuration file smarty.php, but not all pages are suitable for caching, so when configuring the display method in MY_Controller, parameters should be added to clear the cache by default, which requires caching. The page only needs to pass the second parameter as true when calling the display method. After using the cache, if you do not need to cache locally, you can use the {nocache}{/nocache} tag package. If the tag is not cached, the method is to add nocache after the tag, such as {foreach $arr as $v nocache}

7 If the entire project does not use caching, you can remove the lines $config['cache_lifetime'] = 3600; $config['caching'] = true; in smarty.php, and remove the second line from the display method in MY_Controller. Parameters and related judgments

The above is the detailed content of Integration steps of smarty3 under CI framework (with code). For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:cnblogs.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template