Smarty(模板引擎) 原创
一、什么是模板引擎?
Smarty是一个php模板引擎。更准确的说,它分开了逻辑程序和外在的内容,提供了一种易于管理的方法。可以描述为应用程序员和美工扮演了不同的角色,
因为在大多数情况下,他们不可能是同一个人;分开编写,加快开发进度!
二、自定义模板引擎
引擎类:Mytpl.class.php
class Mytpl{
private $data = array();
private $newFile;
//接收数据
public function assign($key,$val){
$this->data[$key] = $val;
}
//显示模版
public function display($tpl){
/*
$userlist = $this->data['userlist'];
$title = $this->data['title'];
*/
/*
foreach($this->data as $key=>$val){
// $userlist
$$key = $val;
}
*/
$this->bianyi($tpl);
//多学点知识,少写点代码
extract($this->data);
include $this->newFile;
}
public function bianyi($tpl){
$html = file_get_contents($tpl);
//正则
// {$title}
$match = '/\{(.*?)\}/';
//替换
$html = preg_replace($match,'',$html);
//重新保存文件
$this->newFile = './view_c/'.md5($tpl).'.php';
file_put_contents($this->newFile,$html);
}
}
?>
执行的PHP文件:(导入引擎类)v5.php
//查询数据库
//在页面顶端做所有的逻辑处理,下面的html代码里面只负责显示
$arr = array(
array('id'=>1,'name'=>'bobo','age'=>18),
array('id'=>1,'name'=>'bobo','age'=>18),
array('id'=>1,'name'=>'bobo','age'=>18),
array('id'=>1,'name'=>'bobo','age'=>18),
);
$title = '测试标题';
//包含类文件
include './Mytpl.php';
//实例化对象
$tpl = new Mytpl();
//分配数据
$tpl->assign('userlist', $arr);
$tpl->assign('title', $title);
$tpl->assign('msg', '测试字符串');
$tpl->display('./view/tpl.php');
?>
调用的模板:(前端美工)index.html(后缀名也可以使用其他.tpl)
Index
{$title}
三、选择Smarty引擎
概述:在引擎中,Smarty将模板“编译”(基于复制和转换)成PHP脚本。它只会发生一次,当第一次读取模板的时候,
指针前进时调取编译版本,Smarty帮你保管它,因此模板设计者只需要编辑Smarty模板,而不必管理编译版本。这也使
得模板很容易维护,而执行速度非常快,因为它只是PHP。如果开启模板缓存,则直接运行缓存的静态页面,而不再去执行
PHP的应用程序(没有反复链接数据库和执行大量SQL语句的动作),大大提高了页面的访问速度。
Smarty模板引擎优点:
1.速度:相对于其他的模板引擎技术而言,采用Smarty编写的程序可以获取最大速度的提高,最主要的是可以提高开发速度,程序员、美工能够
快速开发部署,易于维护。
2.编译型:采用Smarty编写的程序运行时要编译(组合)成一个非模板技术的PHP文件,这个文件采用PHP和HTML混合的方式,在下一次访问模
板时将Web请求直接转换到这个文件中,而不再进行模板重新编译(在源程序没有改动的情况下),使后续的调用速度更快
3.缓存技术:Smarty提供了一个可选择使用的缓存技术,它可以将用户最终看到的HTML文件缓存成一个静态的HTML页面。当用户开启Smarty
缓存时,并在设定的时间内,将用户的Web请求直接转换到这个静态的HTML文件中来,这相当于调用一个静态的HTML文件。
4.插件技术:Smarty模板引擎是采用PHP面向对象技术实现的,不仅可以在源代码中修改,还可以自定义一些功能插件(就是一些按规则自
定义的功能函数)。
5.强大的表现逻辑:PHP负责后台,Smarty模板负责前端。在Smarty模板中能够通过条件判断及迭代地处理数据,它实际上也是一种自定义的
程序设计语言,客户在开发中富有弹性。并抛弃应用程序中PHP与其他语言杂糅的描述方式,使之统一样式,从PHP独立出来,比较安全,另
外,语法简单,容易理解,不必具备PHP知识。
6.模板继承:模板的继承是Smarty 3的新事物,它也是诸多伟大新特性之一。在模板继承里,我们将保持模板作为独立页面而不用加载其他页
面,可以操纵内容块继承它们。这使得模板更直观,更有效和易管理。
四、安装Smarty及初始化配置
概要:
Smarty的安装比较容易,因为它不属于PHP的应用扩展模块,只是采用PHP面向对象思想编写的软件,只要在我们
的PHP脚本中加载Smarty类,并创建一个Smarty对象,就可以使用Smarty模板引擎了。
安装:
步骤如下:
1.需要到Smarty官网http://www.smarty.net/download.php下载最新稳定版本,所有版本的Smarty类库都可以
在UNIX和Windows服务器上使用。
2.然后解压压缩包,解开后看到很多文件,其中有一个名称为libs的文件夹,就是存有Smarty类库的文件夹。其他
文件可以删除,把libs目录拷贝到需要使用的位置。
3.在libs中应该会有Smarty.class.php和SmartyBC.class.php两个文件、一个debug.tpl、一个自定义插件plugins
文件夹(外部使用可以扩充)和一个系统插件sysplugins文件夹(内部插件)。直接将libs目录赋值指定的位置
(libs可以改名,不建议更改)
4.在执行的PHP脚本中,通过require()语句或include()语句将libs目录中的Smarty.class.php类文件加载进来,
Smarty类库就可以使用了(注意Smarty.class.php中的‘S’大写),其他的类文件都会在Smarty类中自动
加载完成。
注意:Smarty3.0必须在PHP5以上的版本运行。
初始化类库的默认设置:
//一个简单的smarty示例
//穿内裤
include './libs/Smarty.class.php';
//实例化对象
$smarty = new Smarty();
//修改默认配置
//定界符
$smarty->setLeftDelimiter('<{'); //方法设置推荐
//$smarty->left_delimiter = '<{'; //属性设置
$smarty->right_delimiter = '}>'; //属性设置
//设置模板路径
$smarty->setTemplateDir('./view');
//设置编译后文件路径
$smarty->setCompileDir('./runtime/view_c');
//设置缓存路径(要开启缓存这个目录才会被使用)
$smarty->setCacheDir('./runtime/cache');
//设置配置文件路径
$smarty->setConfigDir('./config');
//分配数据
$smarty->assign('title','good');
//调用模板
$smarty->display('1.html');
?>
init.inc.php
//初始化Smarty成员属性的公用文件init.inc.php
define('ROOT',str_replace("\\","/",dirname(_FILE_)),'/'); //指定项目的根路径
require ROOT.'libs/Smarty.class.php'; //加载smarty类文件
$smarty = new Smarty();
//实例化smarty类对象$smarty
/*推荐使用smarty3以上版本方式设置默认路径,设置成功后都返回$smarty对象本身,可以使用连贯操作 */
$smarty->setTemplateDir(ROOT.'templates/'); //设置所有模板文件存放的目录
// ->addTemplateDir(ROOT.'templates2') //可以添加多个模板目录(前后台各一个)
->setCompileDir(ROOT.'templates_c/')
//设置所有编译过的模板文件存放目录
->setPluginsDir(ROOT.'plugins/')
//设置模板扩充插件存放目录
->setCacheDir(ROOT.'cache/')
//设置缓存文件存放的目录(开启缓存才被使用)
->setConfigDir(ROOT.'configs'); //设置模板配置文件存放的目录
$smarty->caching = false; //设置smarty缓存开关1开启 0 关闭 ture开启 false 关闭
$smarty->cache_lifetime = 60*60*24 //设置模板缓存有时间段的长度为1天
$smarty->left_delimiter = '<{'; //设置模板语言中的左结束符号
$smarty->right_delimiter = '}>'; //设置模板语言中的右结束符号
/*初始化配置说明*/
//smarty2时的设置方式:
/*
$smarty->template_dir = "./templates"; //设置模板目录,2.0设置方法,3.0沿用但不支持
$smarty->compile_dir = "./templates_c"; //设置编译目录。2.0设置方法,3.0沿用但不init持
$smarty->config_dir = "./configs/";
//设置编译目录。2.0设置方法,3.0沿用但不支持
$smarty->cache_dir = "./cache/";
//设置编译目录。2.0设置方法,3.0沿用但不支持
*/
//smarty3对属性进行了封装,可以使用如下方法进行访问获得目录
$smarty->getCacheDir(); //得到当前缓存目录路径
$smarty->getTemplateDir();
//得到当前模板目录路径的数组
$smarty->getConfigDir(); //得到当前配置文件目录路径
$smarty->getCompileDir(); //得到当前编译目录路径
$smarty->getPluginsDir(); //得到当前插件目录路径数组
//同样下面的方法进行目录设置:
//设置新的模板目录,注意设置后模板目录的数组只有该值一个,不管原来有几个值
$smarty->setTemplateDir("./templates/");
$smarty->setCompileDir("./templates_c/"); //设置新的编译目录
$smarty->setConfigDir("./configs/"); //设置新的配置文件目录
$smarty->setCacheDir("./cache/");
//设置新的缓存目录
$smarty->setLeftDelimiter('<{'); //方法设置推荐
$smarty->setRightDelimiter('<{'); //方法设置推荐
//引用的模板文件的路径必须在模板目录数组中,否则报错,由于仍然用原来的模板文件,这样模板数组中有两个路径。
$smarty->addTemplateDir('./templates2/');
//添加一个新的插件目录,如果用set将取消插件数组,变为单指
$smarty->addPluginsDir('./myplugins');
//说明:这些Smarty对象中的设置方法,设置成功后返回的还是Smarty类对象($this),所以可以像
//init.inc.php脚本中应用的方式一样,采用对象连贯操作方式部署smarty路径。
/*初始化配置说明*/
五、Smarty的基本应用
概述:Smarty引擎既然是分离Web应用程序逻辑层和表现层的工具,目的也是让应用程序员和美工分开扮演不同的角色。
所以程序员和美工都需要学习和使用Smarty,但是学习的内容方向有所不同。
作为程序员需要学习Smarty的“模板程序员篇”,美工学习Smarty的“模板设计篇”,
模板程序员篇
Smarty引擎的安装
变量的分配和加载显示模板
assign()
分配数据:(第四步)
语法:
void assign(string varname, mixed var) //传递一对名称/数组对到模板中
void assign(mixed var) //传递包含名称/数值的关联数组到模板中使用
$smarty->assign('title','这是一个标题');
$smarty->assign('title',$title);
$arr = array(
1=>'lamp85',
3=>'lamp83',
7=>'lamp81',
9=>'lamp89'
);
$smarty->assign('grade',$arr);
display()
调用显示模板:一个脚本中只能使用一次;
viod display(string template)
以插件形式扩展Smarty
缓存控制技术
模板设计者篇
编写Smarty模板的基本语法
变量
变量修改器和组合修改器
自定义函数
Smarty内置函数
模板继承机制