boeiBlog是一套支持多模板的单用户版网络日志程序
其模板引擎采用的是phplib7.4版。此版本修正了以前的大部分bug,文件位于class/template.class.php,有兴趣的朋友可以打开看看。 这是一套解析型的模板,而不是smarty之类的编译型。用这套模板的好处是模板页面可以很简单,但程序因为要替换模板中的标签,因此比较慢。 好在此系统是为个人用户准备的。效率是放在第二位,易用性是放在首位的,因此仍然采用的是phplib的模板。
语法介绍: phplib中常用的方法有set_file,set_block,set_var,parse,ppasre,p,get等。
声明:由于本系统采用的是phplib,如果页面中有大括号对,这将会替换成空白,所以在写此文章时,用"[[","]]"来替代大括号。大家在用的时候是用大括号便是,此处仅为写文章方便而作此约定。
set_file:是用来引入模板文件。 用法:
CODE: |
$t->set_file("show_main","main.htm"); 或 $t->set_file(array( "show_header"=>"header.htm", "show_main"=>"main.htm" )); | | set_block:用来声明一个区块 用法: $t->set_block("show_main","rowlist","RL"); 稍微解释一下,show_main是用set_file取得的文件句柄,rowlist是模板页面中的区域标识一般如下方式来写
CODE: |
<table> <!-- BEGIN rowlist --> <tr> <td>[[param]]</td> </tr> <!-- END rowlist --> </table> | | 如上是将<tr></tr>作为了一个区块,这样就可以用循环来生成多行的列表了 区块是可以嵌套的
CODE: |
<table> <!-- BEGIN rowlist --> <tr> <!-- BEGIN collist --> <td>[[param]]</td> <!-- END collist --> </tr> <!-- END rowlist --> </table> | | 如上所示,这声明一个嵌套区块,这在boeiBlog的像册部分采用了这种方式,有兴趣的朋友可以找出来看看 对于嵌套的模板,我们可以这样来使用 $t->set_block("show_main","rowlist","RL"); // 里面的参数从前向后依次是包含的关系,最后一个是别名,主要用来区块识别 $t->set_block("rowlist","collist","CL"); // 第一个参数是外层块的名称,第二个是自己的名乐,第三个是别名 循环这样的区块时要特别注意 如下:
CODE: |
$t->set_block("show_main","rowlist","RL"); $t->set_block("rowlist","collist","CL"); for($i=0;$i<5;$i++) { $t->set_var("CL");// 这里要对追加的列循环执行一次清理,否则会多出一堆东西 for($ii=0;$ii<5;$ii++) { $t->set_var("param","boeiBlog"); $t->parse("CL","collist",true);// true参数表明这是追加 } $t->parse("RL","rowlist",true);// 这里的true也是表追加 } | | 上述代码将会产生一个5X5的表格,每个单元格里会出现一个boeiBlog
set_var:用来作变量替换 上述代码里的$t->set_var("param","boeiBlog");就是把模板中的param变量替换成boeiBlog这个字符串,当然也可以替换成变量,如:
CODE: |
$curdate = date("Y-m-d"); $t->set_var("param",$curdate); | |
set_var也有追加属性,如:
CODE: |
$curdate = date("Y-m-d"); for($i=0;$i<10;$i++) { $t->set_var("param","<br>".$curdate,true); } | | 这将产生十个连续的当前日期 有时候可以用set_var的追加属性来替代block的循环.
set_var是可以用数组的,如:
CODE: |
$t->set_var(array( "param"=>"boeiBlog", "title"=>"柏艾网络" )); | |
模板如下:
CODE: |
<table> <tr> <td>[[param]],[[title]]</td> </tr> </table> | |
parse:用于解析文件 当我们将模板中的所有变量都处理完之后,可以用parse一将这个模板进行解析。这是模板处理的最后几道工序。 如:
CODE: |
$t->set_file("show_index","index.htm"); $t->set_file("show_main","main.htm"); $t->set_var("param","boeiBlog"); $t->parse("main","show_main"); | |
我们所用的模板可能是:
CODE: |
main.htm <table> <tr> <td>[[param]]</td> </tr> </table> | |
如果此时还有另外一个模板,其结构如下:
CODE: |
index.htm <div>[[main]]</div> | | 那么上述代码将会把main.htm中的变量替换成boeiBlog后再放到index.htm中的main处,最后形成一个在<div></div>标签中的表格
解析完成之后便是输出页面,
p:用于输出页面 如:
CODE: |
$t->set_file("show_index","index.htm"); $t->set_file("show_main","main.htm"); $t->set_var("param","boeiBlog"); $t->parse("main","show_main"); $t->parse("index","show_index"); $t->p("index");// 此处便会将整个index页面输出,注意main.htm已经被嵌入到index.htm,所以不用$t->p("main"); | |
pparse:同p一样也用来输出页面 如:
CODE: |
上述代码可以如下简化 $t->set_file("show_index","index.htm"); $t->set_file("show_main","main.htm"); $t->set_var("param","boeiBlog"); $t->parse("main","show_main"); $t->pparse("index","show_index");// 此处将p和parse结合到一起,立即完成解析并输出 | |
get:用于获得文件内容 如:
CODE: |
$t->set_file("show_index","index.htm"); $t->set_file("show_main","main.htm"); $t->set_var("param","boeiBlog"); $t->parse("main","show_main"); $t->parse("index","show_index"); $getstr = $t->get("index"); echo $getstr;// 你将会看到这实际上和p是一样的。 | | 利用get,我们可以轻松的取得生成页面的内容,这可以用于静态页面的生成。可以看到phplib用来处理静态页面是非常方便的 |