龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > web编程 > php编程 >

smarty应用示例入门

时间:2011-12-23 23:55来源:未知 作者:admin 点击:
分享到:
折叠 展开 PHP Code 复制内容到剪贴板 include_once ( ./comm/Smarty.class.php ); //包含smarty类文件 $smarty = new Smarty(); //建立smarty实例对象$smarty $smarty -templates( ./templates ); //设置模板目录 $smarty -tem
折叠PHP Code复制内容到剪贴板
  1. include_once("./comm/Smarty.class.php"); //包含smarty类文件    
  2. $smarty = new Smarty(); //建立smarty实例对象$smarty    
  3. $smarty->templates("./templates"); //设置模板目录    
  4. $smarty->templates_c("./templates_c"); //设置编译目录    
  5. //****大家注意,这里我是我新加入的****//    
  6. $smarty->cache("./cache"); //设置缓存目录    
  7. $smarty->cache_lifetime = 60 * 60 * 24; //设置缓存时间    
  8. $smarty->caching = true; //设置缓存方式    
  9. //----------------------------------------------------    
  10. //左右边界符,默认为{},但实际应用当中容易与JavaScript    
  11. //相冲突,所以建议设成<{}>或其它。    
  12. //----------------------------------------------------    
  13. $smarty->left_delimiter = "<{";    
  14. $smarty->right_delimiter = "}>";    
  15. $smarty->assign("name""李晓军"); //进行模板变量替换    
  16. //编译并显示位于./templates下的index.tpl模板    
  17. $smarty->display("index.tpl");    
  18. ?>    
  19.   

 

我们可以看到,smarty的程序部分实际就是符合php语言规范的一组代码,我们依次来解释一下:
1。/**/语句:
包含的部分为程序篇头注释。主要的内容应该为对程序的作用,版权与作者及编写时间做一个简单的介绍,这在smarty中不是必
需的,但从程序的风格来讲,这是一个好的风格。
2。include_once语句:
它将安装到网站的smarty文件包含到当前文件中,注意包含的路径一定要写正确。
3。$smarty = new Smarty():
这一句新建一个Smarty对象$smarty,简单的一个对象的实例化。
4。$smarty->templates(""):
这一句指明$smarty对象使用tpl模板时的路径,它是一个目录,在没有这一句时,Smarty默认的模板路径为当前目录的templates
目录,实际在写程序时,我们要将这一句写明,这也是一种好的程序风格。
5。$smarty->templates_c(""):
这一句指明$smarty对象进行编译时的目录。在模板设计篇我们已经知道Smarty是一种编译型模板语言,而这个目录,就是它编译
模板的目录,这里要注意,如果站点位于*nix服务器上,请确保teamplates_c里定义的这个目录具有可写可读权限,默认情况下它的编译目录
是当前目录下的templates_c,出于同样的理由我们将其明确的写出来。
6。$smarty->left_delimiter与$smarty->right_delimiter:
指明在查找模板变量时的左右分割符。默认情况下为"{"与"}",但在实际中因为我们要在模板中使用<script>,Script中的函数定
义难免会使用{},虽然它有自己的解决办法,但习惯上我们将它重新定义为"<{"与"}>"或是"<!--{"与"}-->"或其它标志符,注意,如果在这里
定义了左右分割符后,在模板文件中相应的要使每一个变量使用与定义相同的符号,例如在这里指定为"<{"与"}>",tpl模板中也要相应的将
{$name}变成<{$name}>,这样程序才可以正确的找到模板变量。
7。$smarty->cache("./cache"):
告诉Smarty输出的模板文件缓存的位置。上一篇我们知道Smarty最大的优点在于它可以缓存,这里就是设置缓存的目录。默认情
况下为当前目录下的cache目录,与templates_c目录相当,在*nix系统中我们要确保它的可读可写性。
8. $smarty->cache_lifetime = 60 * 60 * 24:
这里将以秒为单位进行计算缓存有效的时间。第一次缓存时间到期时当Smarty的caching变量设置为true时缓存将被重建。当它的
取值为-1时表示建立起的缓存从不过期,为0时表示在程序每次执行时缓存总是被重新建立。上面的设置表示将cache_lifetime设置为一天。
9. $smarty->caching = 1:
这个属性告诉Smarty是否要进行缓存以及缓存的方式。它可以取3个值,0:Smarty默认值,表示不对模板进行缓存;1:表示
Smarty将使用当前定义的cache_lifetime来决定是否结束cache;2:表示Smarty将使用在cache被建立时使用cache_lifetime这个值。习惯上使
用true与false来表示是否进行缓存。
10. $smarty->assign("name", "李晓军"):
该数的原型为assign(string varname, mixed var),varname为模板中使用的模板变量,var指出要将模板变量替换的变量名;其
第二种原形为assign(mixed var),我们要在后面的例子详细的讲解这个成员函数的使用方法,assign是Smarty的核心函数之一,所有对模板变
量的替换都要使用它。
11. $smarty->display("index.tpl"):
该函数原形为display(string varname),作用为显示一个模板。简单的讲,它将分析处理过的模板显示出来,这里的模板文件不
用加路径,只要使用一个文件名就可以了,它路径我们已经在$smarty->templates(string path)中定义过了。
程序执行完后我们可以打开当前目录下的templates_c与cache目录,就会发现在下边多出一些%%的目录,这些目录就是Smarty的编译与
缓存目录,它由程序自动生成,不要直接对这些生成的文件进行修改。
以上我简单的把Smarty程序中的一些常用的基本元素介绍了一下,在后边的例子中你可以看到将它们将被多次的使用。
接下来介绍一个section循环块与foreach循环块,本来它应该属于模板部分,但是由于它们是smarty的精华所在,而且与smarty程序设计
部分联系非常紧密,所以就在本节单独拿出来讲一下。
1. foreach:用于循环简单数组,它是一个选择性的section循环,它的定义格式为:
{foreach from=$array item=array_id}
{foreachelse}
{/foreach}
其中,from 指出要循环的数组变量,item为要循环的变量名称,循环次数由from所指定的数组变量的个数所决定。{foreachelse}用来当
程序中传递过来的数组为空时的处理,下面是一个简单的例子:

折叠PHP Code复制内容到剪贴板
  1. ===========================================    
  2. example6.tpl    
  3. ===========================================    
  4. <html>    
  5. <head><title>这是一个foreach使用的例子</title></head>    
  6. <body>    
  7. 这里将输出一个数组:<br>    
  8. {foreach from=$newsArray item=newsID}    
  9. 新闻编号:{$newsID}<br>    
  10. 新闻内容:{$newsTitle}<br><hr>    
  11. {foreachelse}    
  12. 对不起,数据库中没有新闻输出!    
  13. {/foreach}    
  14. </body>    
  15. </html>    
  16. ==========================================    
  17. example6.php    
  18. ==========================================    
  19. <?php    
  20. /*********************************************   
  21.  
  22. * 文件名: example6.php   
  23. * 作 用: 显示实例程序2   
  24.  
  25. * 作 者: 大师兄   
  26. * Email: teacherli@163.com   
  27.  
  28. *********************************************/    
  29. include_once("./comm/Smarty.class.php");    
  30. $smarty = new Smarty();    
  31. $smarty->templates("./templates"); //一般不要,要了出错.自己实验得出    
  32. $smarty->templates_c("./templates_c"); //一般不要,要了出错.自己实验得    
  33. $smarty->cache("./cache"); //一般不要,要了出错.自己实验得    
  34. $smarty->cache_lifetime = 0; //一般不要,要了出错.自己实验得    
  35. $smarty->caching = true; //一般不要,要了出错.自己实验得    
  36. $smarty->left_delimiter = "<{";    
  37. $smarty->right_delimiter = "}>";    
  38. $array[] = array("newsID"=>1, "newsTitle"=>"第1条新闻");    
  39. $array[] = array("newsID"=>2, "newsTitle"=>"第2条新闻");    
  40. $array[] = array("newsID"=>3, "newsTitle"=>"第3条新闻");    
  41. $array[] = array("newsID"=>4, "newsTitle"=>"第4条新闻");    
  42. $array[] = array("newsID"=>5, "newsTitle"=>"第5条新闻");    
  43. $array[] = array("newsID"=>6, "newsTitle"=>"第6条新闻");    
  44. $smarty->assign("newsArray"$array);    
  45. //编译并显示位于./templates下的index.tpl模板    
  46. $smarty->display("example6.tpl");    
  47. ?>   

精彩图集

赞助商链接