This article mainly introduces the steps of integrating smarty into the CI framework, and analyzes in detail the configuration skills and calling methods of Smarty in the CI framework in the form of examples. Friends in need can refer to it. I hope to be helpful.
The details are as follows:
Ci combined with smarty configuration steps:
1. The first step is to configure ci and download the smarty template. I like to use it ( Smarty-3.1.8) this version.
2. In the second step, unzip the downloaded smarty version and rename the libs file inside to smarty, then copy this file to the ci\application\libraries directory
3. In ci Create a file under the \application\libraries directory. The file name can be customized. For example, see a tp.php document.
4. Open tp.php with the compiler and write the following code:
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed'); require_once('smarty/smarty.class.php'); class Tp extends Smarty{ function tp(){ parent::Smarty(); $this->template_dir = APPPATH.'views'; $this->compile_dir = APPPATH.'templates_c/'; $this->left_delimiter = '<{'; $this->right_delimiter = '}>'; } }
5. Create a ci\application\templates_c folder
6. Open ci \application\config\autoload.php file, change
$autoload['libraries'] = array();
to:
$autoload['libraries'] = array('database','tp');
OK our configuration has been successful here, next we start testing
The first step in testing is to create a controller:
1. Create a file named ceshi.php under \application\controllers with the file content
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed'); class Home extends CI_Controller { function __construct() { parent::__construct(); $this->load->helper('url'); $this->tp->assign('base_url', base_url()); //定义css以及js的路径 } function index() { $this->tp->assign("title","恭喜你smarty安装成功!"); $this->tp->assign("body","欢迎使用smarty模板引擎"); $arr = array(1=>'zhang',2=>'xing',3=>'wang'); $this->tp->assign("myarray",$arr); $this->tp->display('ceshi.html'); } }
2. Create a template file. Create a file named ceshi.html in the ci\application\views directory. The file content is
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <script src='<!--{$base_url}-->js/jQuery.min.js' type='text/JavaScript' ></script> <link href="<!--{$base_url}-->css/login.css" rel="stylesheet" type="text/css" /> <title>smarty安装测试</title> </head> <body> <h1><{$title}></h1> <p><{$body}></p> <ul> <{foreach from=$myarray item=v}> <li><{$v}></li> <{/foreach}> </ul> </body> </html>
and finally enter the address http://localhost/ci/application/index.php/ After running ceshi (the idea ci represents the root directory where you place the files in the ci framework), you will see the page where you have successfully configured smarty. At this point, the integration and testing of ci and smarty are complete
Related recommendations:
Analysis of the benefits of CI framework using singleton pattern design
From Instructions for using the php cache file extracted from the CI framework
Enable debugging mode in the CI framework
The above is the detailed content of Detailed explanation of CI framework integration smarty examples. For more information, please follow other related articles on the PHP Chinese website!