[分享]STE---轻型PHP模板引擎下载

井通
2023-12-01

 本文提供的附件下载是:

http://syu.javaeye.com/topics/download/4a0e681f-6fda-358f-ae51-401a8f968eae

http://syu.javaeye.com/blog/372544

 

 

特别注明:

    STE是基于SmartTemplate的修改版本,其在SmartTemplate的设计上做了大量修改,以及使用PHP5的语法进行了重写. Smarttemplate是一套较轻型的PHP模板处理引擎,相对于流行的Smarty,它更加小巧灵活,但功能却仍然强大。重要的是它的设计思想不像其它模板处理引擎那样追求大而全。而在于尽量减少页面内的逻辑流程,将模板与最终视图之间的差异性降到最低。这也是我这么多年来业直使用Smarttemplate而不是smarty的原因。(两者之间的差异比较,请访问我的另一篇博客 http://blog.csdn.net/syu/archive/2008/12/12/3502884.aspx

   

    修改的必要性:

    SmartTemplate很久没有更新了,第一次使用它是大概在2002年左右,直到2008年它还是当初那个样子 :-( 而在这些日子里,除去PHP本身发生了很大的变化,我在很多次使用中也认为它的功能不足以满足我的需求。因此决定在某一个晚上花费一点休息时间将它进行重构。

 

    修改的部份:

    1. IF 条件进行了改写,现在你可以在IF里使用多种判断条件,比如 and 或者 or,尽管这在其它模板引擎里早已实现。但原来的Smarttemplate仅仅支持 等于 或 空值判断。

    2. BEGIN 循环处理进行了改写,在BEGIN里除了注册的变量单位外,还可以完全使用 {_KEY},{_VALUE},{_ROWCNT},{_ROWBIT}这样的内部变量。

    3. 增加了$_SESSION,$_SERVER,$_GLOBALS的PHP超级全局变量访问形式,可以不用注册而直接在页面中使用类似{SESSION.username}的方式访问一些频繁使用的超全局变量。

    4.增加了INCLUDE语法的模板嵌套。这样一些多个页面中使用的相同部份,比如头部和尾部,就可以被直接嵌套。而不用在每个页面中写入相同的代码。

    5.改写了smarttemplate的扩展处理模式,可以在页面中使用任何已注册的函数,或者自动装载为smarttemplate准备的扩展插件。在页面中可以直接用{date:'Y-m-h'}的形式显示当前时间,相当于<?php echo date('Y-m-h');?>

    6.改写了编译机制和缓存机制。

    7.使用PHP5.3语法以及OOP进行重写。

    8.去掉了debuger部份,并将原来的两个文件合并成为一个,减少了一次include.

    9.优化了不少结构和算法,增加了加载配置方法,改写了原有的读取$_CONF数组配置的方式,减少了冲突的可能。

    10.实在想不起来了。

 

    使用说明:

    一,生成实例对象、指定模板页面、加载配置、输出页面

      <?php  

          include('ste.class.php');

          $tpl = new ste( ) ;               //只实例化对象。稍后指定模板页面

          //$tpl = new ste('tpl.html');    实例化的同时,指定模板页面

          $tpl -> LoadConfig(array('compiled_dir'=>'./tpl_compiled/','template_dir' =>'./tpl/'));   //加载配置

          $tpl -> output();

         /*

          其中配置项包括:

          template_dir  -------------- 模板文件的默认存放目录。

          compiled_dir  -------------- 编译后模板文件的存放目录

          ext_dir           -------------- STE扩展插件目录

          cache_dir       -------------- 缓存文件生成后的存放目录

          cache_lifetime-------------- 缓存文件的生命周期,秒为单位

        */

       ?>

   二,变量注册,追加以及页面中的表现形式

     <?php

         .........

         /*

              $hi = 'hello!',单变量注册,在模板中可以用 {hi}来显示

         */

         $tpl -> assign('hi',$hi); 

 

        /*

             $arrayData=array('a'=>1,'b'=>2) ,数组变量集体注册,页面中可用{a},{b}来显示元素         

         */

         $tpl -> assign($arrayData);

 

        /*

           $data = array(0=>array('id'=>1,'name'=>'a'),1=>array('id'=>2,'name' =>'b'));

           注册循环数组,页面中可用BEGIN语法循环输出

        */

         $tpl -> assign('data',$data);

 

        /*

           $data 可以等于数组,也可以是单变量。append方法将数据追加到原有注册标签中。

           如果原有注册标签是单变量,新值将以(.)形式追加。如果原有标签是数组,将以([])形式追加

        */

         $tpl -> append('data',$data);        

    

      三,逻辑控制和循环

      在页面中进行逻辑控制。使用 <!-- IF ELSE ELSEIF ENDIF -->方式。

      <!-- IF {a}>100 -->

          显示一段HTML代码

      <!-- ELSEIF {a}>20 -->

          显示另一段HTML代码

      <!-- ELSE -->

          显示其它的HTML代码

      <!-- ENDIF -->  

     

      在页面中使用循环输出,使用<!-- BEGIN 注册变量名 --> <!-- END 注册变量名 -->方式 .

       //一维数组循环:$tpl->assign('test',array(1,2,3,4,5));

      <!-- BEGIN test -->

         {_VALUE}

      <!-- END test -->

  

       //带键值的一维数组循环:$tpl->assign('test',array('a'=>1,'b'=>2,'c'=>3));

      <!-- BEGIN test -->

         {_KEY}的值是:{_VALUE}

      <!-- END test -->

 

       /* 二维数组循环(比如从数据库中取出的数据):

           $tpl -> assign('test',array(0=>array('id'=>1,'name'=>'a'),1=>array('id'=>2,'name' =>'b')));

      */

      <!-- BEGIN test -->

         {id}对应的name值是:{name}

      <!-- END test -->

       

      循环体中内置的还有:

      {_ROWCNT}  ----- 从1开始计数的自增变量。可用于在列表中显示顺序。

      {_ROWBIT}   ----- 从0到1的替换值。第一行是0,第二行是1,第三行是0,以此类推。用于两列间不同css样式的值

      四,页面模板嵌套

      STE中可以自由嵌套模板。使用方法为 <!-- INCLUDE 模板名 -->

      比如一个网站模板,我们可以把公用的头,尾部份分离出来供许多其它页面模板调用。

      <!-- INCLUDE head.html -->

        .................其它模板代码

      <!-- INCLUDE foot.html -->

       值得注意的是,引用了嵌套页面的主模板,在被嵌套的页面代码发生了改变时,需要手工清理一下编译缓存,重新编译方能生效。这样做是为了加快速度。STE的缓存机制虽然能够在模板发生改变时自动重新编译,但凡是引入了嵌套的模板,为了避免每次使用都重新读入嵌套页面,会在编译时将嵌入页面的所有代码读入,与自身成为一体。

 

      五,页面中使用函数以及STE插件

      在页面中,你可以通过{函数名:参数1,参数2...}的形式任意引用PHP内置的、或者你自身定义的函数。并且能够自由管理参数(原有的smarttemplate只允许使用最多两个参数)。比如,需要在页面中显示一个当前时间时,可以使用

     {date:'Y-m-d'}这样的方式。

      在参数表中,允许使用的参数包括

      1   字符串   使用单引号或者双引号连接,但不接受诸如 (.)这样的操作符

      2   数学      直接的数学字符,比如  123

      3   注册的变量名  比如 $tpl ->assign('var',123);后,在页面中可以使用 {userfunc:var}的形式。

 

      当引用的函数名不存在时,会自动的加载STE插件目录下的文件(根据配置中ext_dir目录读取)。比如当引用 {usericon:uid}时。如果usericon函数没有被定义。STE将自动找寻ext_dir目录中 ste_ext_usericon.class.php文件,并将其读入,在这个文件中,应该有关于usericon函数的定义。

 

       当不需要将一个函数的结果输出时(例如函数体内部本身就带有输出。而函数返回的仅仅是一个True或False)时,可以在函数名前面加上 (^)符以关闭输出,比如 {^usericon:uid}

 

       这里有一点例外的说明是:我不是很赞成在页面中放置太多的函数体以及逻辑判断语句。我一直认同的观点是:

应该尽量减少模板与最终呈现页面之间的差异,模板中引入的尽量保证是变量而不是流程。大量的流程处理请交给程序来执行。这样才能最大化的符合MVC的三层分离思想。在一个模板中大量使用逻辑,或者大量使用函数的话,请问与直接在模板中直接写<?php 又有什么区别呢?再强大的PHP模板引擎也强不过php 本身。

 类似资料: