PHP中Smarty模板的使用
一、 什么是模板引擎
不知道从什么时候开始,有人开始对 HTML 内嵌入 Server Script 觉得不太满意。然而不论是微软的 ASP 或是开放源码的 PHP,都是属于内嵌 Server Script 的网页伺服端语言。因此也就有人想到,如果能把程序应用逻辑 (或称商业应用逻辑) 与网页呈现 (Layout) 逻辑分离的话会比较好。
其实这个问题早就存在已久,从交互式网页开始风行时,不论是 ASP 或是 PHP 的使用者都是身兼程序开发者与视觉设计师两种身份。
所以模版引擎就应运而生啦!模版引擎的目的,就是要达到上述提到的逻辑分离的功能。它能让程序开发者专注于资料的控制或是功能的达成;而视觉设计师则可专注于网页排版,让网页看起来更具有专业感!因此模版引擎很适合公司的网站开发团队使用,使每个人都能发挥其专长!
就笔者接触过的模版引擎来说,依资料呈现方式大概分成:需搭配程序处理的模版引擎和完全由模版本身自行决定的模版引擎两种形式。
在需搭配程序处理的模版引擎中,程序开发者必须要负责变量的呈现逻辑,也就是说他必须把变量的内容在输出到模版前先处理好,才能做 assign 的工作。换句话说,程序开发者还是得多写一些程序来决定变量呈现的风貌。而完全由模版本身自行决定的模版引擎,它允许变量直接 assign 到模版中,让视觉设计师在设计模版时再决定变量要如何呈现。因此它就可能会有另一套属于自己的模版程序语法 (如 Smarty) ,以方便控制变量的呈现。但这样一来,视觉设计师也得学习如何使用模版语言。
二、 自定义模板引擎
引擎类: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)
{$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官网//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路径。
/*初始化配置说明*/