个人工具
名字空间
变换
操作

Smarty

来自站长百科
跳转到: 导航, 搜索
Smarty logo.gif

Smarty模板引擎,是一个使用PHP写出来的模板引擎,它提供了逻辑与外在内容的分离,简单的讲,目的就是要使用PHP程序员同美工分离,使用的程序员改变程序的逻辑内容不会影响到美工的页面设计,美工重新修改页面不会影响到程序的程序逻辑,这在多人合作的项目中显的尤为重要。

目录

Smarty优点

  • 速度:采用smarty编写的程序可以获得最大速度的提高,这一点是相对于其它的模板引擎技术而言的。
  • 编译型:采用smarty编写的程序在运行时要编译成一个非模板技术的PHP文件,这个文件采用了PHP与HTML混合的方式,在下一次访问模板时将Web请求直接转换到这个文件中,而不再进行模板重新编译(在源程序没有改动的情况下)
  • 缓存技术:smarty选用的一种缓存技术,它可以将用户最终看到的HTML文件缓存成一个静态的HTML页,当设定smarty的cache属性为 true时,在smarty设定的cachetime期内将用户的WEB请求直接转换到这个静态的HTML文件中来,这相当于调用一个静态的HTML文件。
  • 插件技术:smarty可以自定义插件。插件实际就是一些自定义的函数。
  • 模板中可以使用if/elseif/else/endif。在模板文件使用判断语句可以非常方便的对模板进行格式重排。

Smarty不适用的情况

  • 需要实时更新的内容。例如像股票显示,它需要经常对数据进行更新,这类型的程序使用smarty会使模板处理速度变慢。
  • 小项目。小项目因为项目简单而美工与程序员兼于一人的项目,使用smarty会丧失php开发迅速的优点。

安装Smarty

安装smarty的环境:php版本4.06以上版本。

安装smarty方法非常简单,从http://samrty.php.net下载smarty将Libs中所有文件拷入comm目录,完成基本安装.


Smarty示例

  • index.tpl
{* 显示是smarty变量识符里的用*包含的文字为注释内容 *}
{include file="header.tpl"}{*页面头*}
大家好,我叫{$name}, 欢迎大家阅读我的smarty学习材料。
{include file="foot.tpl"}{*页面尾*}

上边的这个例子是一个tpl模板,其中:

  1. {**}是模板页的注释,它在smarty对模板进行解析时不进行任何输出,仅供模板设计师对模板进行注释。
  2. include file="xxx.tpl" 使用此句将一个模板文件包含到当前页面中,例子中将在网站中公用事的head.tpl与foot.tpl进行了包含,你可以这样想,使用这一句将xxx.tpl中的内容全部复制在当前语句处。当然,你不使用这一句也可以,将XXX.tpl中的内容复制到当前语句处也是完全可以了。
  3. {$name}: 模板变量,smarty中的核心组成,采用smarty定义的左边界符{与右边界符}包含着、以PHP变量形式给出,在smarty程序中将使用

$smarty->assign("name", "李晓军");将模板中的$name替换成“李晓军”三个字。

整个实例源程序如下:

  • header.tpl
<html>
<head>
<title>大师兄smarty教程</title>
</head>
<body>
  • foot.tpl
<hr>
<center> CopyRight© by 大师兄 2004年8月 Email: teacherli@163.com </center>
<hr>
</body>
</html>


  • index.php
<?php
/*********************************************
*
* 文件名: index.php
* 作 用: 显示实例程序
*
* 作 者: 大师兄
* Email: teacherli@163.com
*
*********************************************/
include_once("./comm/Smarty.class.php"); //包含smarty类文件

$smarty = new Smarty(); //建立smarty实例对象$smarty
$smarty->template_dir = "./templates";//设置模板目录
$smarty->compile_dir = "./templates_c"; //设置编译目录

//----------------------------------------------------
//左右边界符,默认为{},但实际应用当中容易与JavaScript
//相冲突,所以建议设成<{}>或其它。
//----------------------------------------------------
$smarty->left_delimiter = "{";  
$smarty->right_delimiter = "}";

$smarty->assign("name", "李晓军"); //进行模板变量替换

//编译并显示位于./templates下的index.tpl模板
$smarty->display("index.tpl");  
?> 

最终执行这个程序时将显示为:执行index.php

<html>
<head>
<title>大师兄smarty教程</title>
</head>
<body>
大家好,我叫李晓军, 欢迎大家阅读我的smarty学习材料。
<hr>
<center> CopyRight© by 大师兄 2004年8月 Email: teacherli@163.com </center>
<hr>
</body>
</html> 

相关条目

参考来源

留言