smarty模板引擎--php高级最详细教程

Smarty(模板引擎) 原创



一、什么是模板引擎?


Smarty是一个php模板引擎。更准确的说,它分开了逻辑程序和外在的内容,提供了一种易于管理的方法。可以描述为应用程序员和美工扮演了不同的角色,
因为在大多数情况下,他们不可能是同一个人;分开编写,加快开发进度!


二、自定义模板引擎


引擎类:Mytpl.class.php
<?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,'<?php echo $1 ?>',$html);


            //重新保存文件
            $this->newFile = './view_c/'.md5($tpl).'.php';
            file_put_contents($this->newFile,$html);
        }
    }
?>


执行的PHP文件:(导入引擎类)v5.php
<?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)
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="content-type" content="text/html; charset=utf-8">
        <title>Index</title>
    </head>
    <body>
        {$title}
    </body>
</html>




三、选择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以上的版本运行。


初始化类库的默认设置:






<?php
//一个简单的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内置函数


模板继承机制



猜你喜欢

转载自blog.csdn.net/wulove52/article/details/52373764