smarty半小时快速上手教程
一:smarty的程序设计部分:0 U6 Y# p# K. Q0 P( x7 l7 y
在smarty的模板设计部分我简单的把smarty在模板中的一些常用设置做了简单的介绍,这一节主要来介绍一下如何在smarty中开始我们程序设计。下载Smarty文件放到你们站点中。2 y4 u) ]: R- L, {# F
index.php PHP代码:
' ]5 n3 t$ O- M
<?php 1 F C5 s+ j# H2 M0 V. p4 J /** * * @version $Id: index.php * @package * @author www.php100.com * @action 显示实例程序 */ . V5 `) ^( ]0 q+ L2 ~4 o include_once("./Smarty/Smarty.class.php"); //包含smarty类文件 $smarty = new Smarty(); //建立smarty实例对象$smarty $smarty->templates("./templates"); //设置模板目录 $smarty->templates_c("./templates_c"); //设置编译目录 $smarty->cache("./cache"); //缓存目录 _( R7 t B0 X+ Q& q, I2 ` $smarty->cache_lifetime = 0; //缓存时间 : B/ ]: X- b" I2 Z1 v: } $smarty->caching = true; //缓存方式 $smarty->left_delimiter = "{#"; $smarty->right_delimiter = "#}"; $smarty->assign("name", "zaocha"); //进行模板变量替换 ' O9 N9 P8 w! X; ? $smarty->display("index.htm"); //编译并显示位于./templates下的index.htm模板 ?> |
二:解释smarty的程序
我们可以看到,smarty的程序部分实际就是符合php语言规范的一组代码,我们依次来解释一下:: k$ ?$ y% T: X2 n- b' r `5 `
1:/**/语句:
包含的部分为程序篇头注释。主要的内容应该为对程序的作用,版权与作者及编写时间做一个简单的介绍,这在smarty中不是必需的,但从程序的风格来讲,这是一个好的风格。
2:include_once语句:
它将安装到网站的smarty文件包含到当前文件中,注意包含的路径一定要写正确。# U6 k8 n5 J' `
+ l* u$ Y ^; x7 ^
3:$smarty = new Smarty():& V% F5 e" M4 Z; j& ~ Y& r0 @
这一句新建一个Smarty对象$smarty,简单的一个对象的实例化。
4:$smarty->templates(""):9 T* {$ c" Q) r, j. J% e$ U
这一句指明$smarty对象使用tpl模板时的路径,它是一个目录,在没有这一句时,Smarty默认的模板路径为当前目录的templates目录,实际在写程序时,我们要将这一句写明,这也是一种好的程序风格。
7 e7 h$ `2 @: | m
5:$smarty->templates_c(""):
这一句指明$smarty对象进行编译时的目录。在模板设计篇我们已经知道Smarty是一种编译型模板语言,而这个目录,就是它编译模板的目录,要注意,如果站点位于linux服务器上,请确保
teamplates_c里定义的这个目录具有可写可读权限,默认情况下它的编译目录是当前目录下的templates_c,出于同样的理由我们将其明确的写出来。( w2 Z0 i. ~1 R, B2 o- P3 H( Q
2 P% j7 }% ~; q- `8 p) {! l
6:$smarty->left_delimiter与$smarty->right_delimiter:
指明在查找模板变量时的左右分割符。默认情况下为"{"与"}",但在实际中因为我们要在模板中使用<script>,Script中的函数定义难免会使用{},虽然它有自己的解决办法,但习惯上我们将它重新定义
为"{#"与"#}"或是"<!--{"与"}-->"或其它标志符,注意,如果在这里定义了左右分割符后,在模板文件中相应的要使每一个变量使用与定义相同的符号,例如在这里指定为"<{"与"}>",htm模板中也要+ x- |5 I1 {0 ]5 [( L, l4 R
相应的将{$name}变成<{$name}>,这样程序才可以正确的找到模板变量。
5 g( d* I" o W9 d. O0 {
7:$smarty->cache("./cache"):& s, N3 y, P, I3 U- f
告诉Smarty输出的模板文件缓存的位置。上一篇我们知道Smarty最大的优点在于它可以缓存,这里就是设置缓存的目录。默认情况下为当前目录下的cache目录,与templates_c目录相当,在linux系统中
我们要确保它的可读可写性。
! {& Z$ i' w) P# L( c1 _
8: $smarty->cache_lifetime = 60 * 60 * 24:3 n5 W5 i! s& Y9 F
这里将以秒为单位进行计算缓存有效的时间。第一次缓存时间到期时当Smarty的caching变量设置为true时缓存将被重建。当它的取值为-1时表示建立起的缓存从不过期,为0时表示在程序每次执行时缓+ O+ s: O, s4 N9 M& |
存总是被重新建立。上面的设置表示将cache_lifetime设置为一天。0 b0 v9 _3 O) A& K; L. y: x- e
7 V3 X4 a6 n0 h8 ]4 h+ s, W
9: $smarty->caching = 1:
这个属性告诉Smarty是否要进行缓存以及缓存的方式。它可以取3个值,0:Smarty默认值,表示不对模板进行缓存;1:表示Smarty将使用当前定义的cache_lifetime来决定是否结束cache;2:表示
Smarty将使用在cache被建立时使用cache_lifetime这个值。习惯上使用true与false来表示是否进行缓存。; t9 U3 t- f# s5 y6 ?; `
10:$smarty->assign("name", "zaocha"):6 I# T1 C- S3 h8 f, [/ z# X
该数的原型为assign(string varname, mixed
var),varname为模板中使用的模板变量,var指出要将模板变量替换的变量名;其第二种原形为assign(mixed
var),我们要在后面的例子详细的讲解这个成员函数的使用方法,assign是Smarty的核心函数之一,所有对模板变量的替换都要使用它。
. D [" |/ Y6 ?1 x* [
11. $smarty->display("index.tpl"):
该函数原形为
display(string
varname),作用为显示一个模板。简单的讲,它将分析处理过的模板显示出来,这里的模板文件不用加路径,只要使用一个文件名就可以了,它路径我们已
经在$smarty->templates(string path)中定义过了。5 b, c" j n; U. i7 y
程序执行完后我们可以打开当前目录下的templates_c与cache目录,就会发现在下边多出一些%%的目录,这些目录就是Smarty的编译与缓存目录,它由程序自动生成,不要直接对这些生成的文件进行修改。) k' b1 G8 k" o2 D
以上我简单的把Smarty程序中的一些常用的基本元素介绍了一下,在后边的例子中你可以看到将它们将被多次的使用。
三:模板说明) p4 r" ^4 f+ Q# k
接下来介绍一个section循环块与foreach循环块,本来它应该属于模板部分,但是由于它们是smarty的精华所在,而且与smarty程序设计部分联系非常紧密,所以就在本节单独拿出来讲一下。
1: foreach:用于循环简单数组,它是一个选择性的section循环,它的定义格式为:2 G. D/ q' k* ~& u, `: E
{foreach from=$array item=array_id} {foreachelse} {/foreach} |
其中,from 指出要循环的数组变量,item为要循环的变量名称,循环次数由from所指定的数组变量的个数所决定。{foreachelse}用来当程序中传递过来的数组为空时的处理,下面是一个简单的例子:
模板文件:example.htm5 l" }: |- w+ j0 o9 L1 }9 e
foreach 输出一个“二维关联数组”的数据:
{#foreach item=new from=$news#} 新闻编号:{#$new.id#} 0 M* O- j- ]0 a* X& Z$ R4 w 新闻内容:{#$new.title#} B% P Y& O8 ?" ~ ' U4 {- I3 D) ?9 b' f1 [ {#foreachelse#} |
数据库中没有新闻输出!
4 I( `8 e" ?& l$ N) j5 w% E$ t8 Q
{#/foreach#} 0 W! |4 J# [4 ~- c8 j" Y {foreach from=$newsArray item=newsID} |
新闻编号:{$newsID} |
6 E- i: y# p+ z/ S$ x
新闻内容:{$newsTitle} |
4 | t" R0 G. t8 D2 |7 z/ L
3 B9 [" D @0 k$ ~
{foreachelse} |
& d( d+ T3 V7 _' T! S
对不起,数据库中没有新闻输出!
3 Y+ J* U* J' a* c3 {" f9 ?
{/foreach} |
这是一个错误的不显示数据,本文做了更正。
程序文件:example.php# X; @+ z0 O: v
" b/ ]( @- Z* ]' j
<? /********************************************* 6 m. s9 M5 z$ |0 N' n4 N/ T: i * 2 H( a/ |0 Q4 @. @5 y * 文件名: example.php * 作 用: 显示实例程序2 *********************************************/ ; S" `) H% v2 i8 \8 z. Y, k; h( v 0 r, ^5 T* T; J4 O$ n3 r" A include_once("./Smarty/Smarty.class.php"); % s9 x7 M! ~6 |, _9 P/ K D& U $smarty = new Smarty(); $smarty->templates("./templates"); 7 b# O+ S; p g# ]( C( @' l* c $smarty->templates_c("./templates_c"); 5 k. V. y Q) G( Q; J0 c& d / W, ~% G5 R1 X7 x+ K. }2 ]5 ^; X $smarty->cache("./cache"); 8 q( k, c8 f* i, J# e# D $smarty->cache_lifetime = 0; 0 U0 x# p7 a! M8 v $smarty->caching = true; 6 Y& s, n- V6 z/ ]1 ]- G $smarty->left_delimiter = "{#"; ! M8 w; u5 K [ A) u $smarty->right_delimiter = "#}"; 9 m9 N% a& S Z4 X) e; [ $array[] = array("newsID"=>1, "newsTitle"=>"第1条新闻"); $ n' V6 W$ O+ k. L4 e9 i $array[] = array("newsID"=>2, "newsTitle"=>"第2条新闻"); + C- Q& V0 l; [+ s $array[] = array("newsID"=>3, "newsTitle"=>"第3条新闻"); : @" q. E, k; x( n w $array[] = array("newsID"=>4, "newsTitle"=>"第4条新闻"); $ \! P, J9 x0 q+ u' {( R, g% b" b 8 W2 }3 [ ~6 X& w5 `& \% F $array[] = array("newsID"=>5, "newsTitle"=>"第5条新闻"); 5 R0 |# s% d/ _$ S# A$ }, E $array[] = array("newsID"=>6, "newsTitle"=>"第6条新闻"); //这是一个二维关联数组 9 X9 w) ]( f- X$ ~! s * W( Y0 p5 x* n) S: j+ y7 [ $smarty->assign("newsArray", $array); //编译并显示位于./templates下的index.htm模板 % r. @0 ]% q" x$ ~* H. K' p 3 L$ l0 t9 [0 S6 @6 j $smarty->display("example.htm"); ; \# A _: t! Y( M7 ~: f* Q ?> |
输入结果:example.php! B& d* l& E+ Z/ B8 ~% j1 ]
这里将输出一个数组:
' V7 T# D& O, h( P3 P
新闻编号:1 新闻内容:第1条新闻 5 n1 N% L/ K; |0 N0 v 新闻编号:2 新闻内容:第2条新闻 , R4 F+ B# G2 _3 y- r0 X 新闻编号:3 新闻内容:第3条新闻 新闻编号:4 , i9 x: e# s. r1 e( R* k C $ R1 D3 D4 [' Y. ]6 ^ 新闻内容:第4条新闻 6 t* b% E* f: C% |" K4 x& w 新闻编号:5 2 m0 }! S& H; Q* ^! m7 w ( N8 G; y6 k0 V" ]) O 新闻内容:第5条新闻 3 H0 _. f9 j) v% f; E# r ) c- k# H+ H" U% r |4 E 新闻编号:6 : V7 u) T4 }$ v" r 新闻内容:第6条新闻 |
6 } L' Y" W4 w: \
foreach还可以用foreachelse来匹配,用foreachelse来表示当传递给foreach的数组为空值时程序要执行的操作,具体的使用方法,请参考手册的说明。
2. section:. S0 ?" a/ m9 Y6 \" D
section的产生是为解决foreach的不足的,与foreach一样,它用于设计模板内的循环块,它较为复杂,可极大程序上满足程序需要,所以在程序中我习惯使用它而不使用foreach,基本原形为:
: P% {% z: x5 A' p0 q& Y/ j; L
{section name = name loop = $varName[, start = $start, step = $step, max = $max, show = true]} |
name: section的名称,不用加$ % F) j0 \/ W7 E/ t7 B $loop: 要循环的变量,在程序中要使用assign对这个变量进行操作。 1 M6 {0 B' j: d $start: 开始循环的下标,循环下标默认由0开始 : l: T2 O# ]( ~) A9 v $step: 每次循环时下标的增数 ' C! k, c+ J! J; T x4 P- c- Z ) T. y( y* s$ E! c9 r $max: 最大循环下标 $show: boolean类型,决定是否对这个块进行显示,默认为true |
这里有个名词需要说明:4 y- ]2 `- g7 _& p' X
循环下标:实际它的英文名称为index,是索引的意思,这里我将它译成"下标",主要是为了好理解。它表示在显示这个循环块时当前的循环索引,默认从0
开始,受$start的影响,如果将$start设为5,它也将从5开始计数,在模板设计部分我们使用过它,这是当前{section}的一个属性,调用
方式为Smarty.section.sectionName.index,这里的sectionName指的是函数原型中的name属性。
{section}块具有的属性值,分别为:. p$ S; ?0 A8 Z1 L& H2 r. C
1. index: 上边我们介绍的"循环下标",默认为0) C6 h9 r& y& K
2. index_prev: 当前下标的前一个值,默认为-1- G8 [# A) F' {1 w& s- t
3. index_next: 当前下标的下一个值,默认为1
4. first: 是否为第一下循环
5. last: 是否为最后一个循环
6. iteration: 循环次数
7. rownum: 当前的行号,iteration的另一个别名/ o. t/ i, o0 t# \. i F
8. loop: 最后一个循环号,可用在section块后统计section的循环次数
9. total: 循环次数,可用在section块后统计循环次数
10. show: 在函数的声明中有它,用于判断section是否显示
它们的具体属性大家可以参考手册,在程序中可灵活使用它的这些属性,模板部分我就使用过index属性,大家可以回过头去看看。
同样,{section}也可以配合使用{sectionelse},用来表示传入的数组变量为空时对模板进行的处理。
我们把上边的那个例子使用{section}来替代{foreach}来实现现样的功能,注意,在这个例子中我只将tpl模板中的{foreach}用{section}来实现,php程序文件中没有任何改动,同时加了{sectionelse}处理块:8 Q, O! z; }4 D0 u1 f
example.tpl
这里将输出一个数组:4 Z# ]9 U" ^8 j: e5 G/ \, Z
{section name=loop loop=$News} ! ]; w4 @2 ~& R) c# l 新闻编号:{$News[loop].newsID} 新闻标题:{$News[loop].newsTitle} {sectionelse} & [( G3 Y4 ^ k* _ s% q 对不起,没有任何新闻输入! {/section} |
example.php+ c- v/ V8 V& L: k& w+ a
<? /********************************************* 1 V5 h' }+ k m. N7 }3 _ * * 文件名: example7.php . R: c8 s0 I" D + w3 @+ D& b" R' }8 n * 作 用: 显示实例程序2 ; \ [, d! j9 w) u- x # K# ]. D, G& d *********************************************/ 8 V0 ~! y3 q* M" t; p 1 b X. j$ _4 Y( U* s. g3 w: V* G# x include_once("./comm/Smarty.class.php"); 1 [& r. ~+ S5 F' t' V& X $smarty = new Smarty(); 3 j& X. {" I: K; Q2 W $smarty->templates("./templates"); 8 }+ F' q$ R% s5 [ B: h: n4 a. X8 E $smarty->templates_c("./templates_c"); 3 b: ^* e% \# X8 g! ^ $smarty->cache("./cache"); ) H& N% Y+ S7 i4 D" W$ V. y3 t* M) M $smarty->cache_lifetime = 0; ( _' X; ]' F; }+ F " z) n# D# f1 z' G/ d y* ?4 U i $smarty->caching = true; & [6 g; I- d" T B2 C$ c3 _ $smarty->left_delimiter = "{"; 1 @7 y# C8 \7 `$ ~5 r9 ]. ~ $smarty->right_delimiter = "}"; : o" Z0 ~, M- A4 c5 R $array[] = array("newsID"=>1, "newsTitle"=>"第1条新闻"); 5 U2 r7 n' b& y9 ]1 f- a " I# K: z3 F5 B3 e/ U/ U+ C5 b $array[] = array("newsID"=>2, "newsTitle"=>"第2条新闻"); $array[] = array("newsID"=>3, "newsTitle"=>"第3条新闻"); 9 ?1 R! q1 B: v! C0 U8 A% b $array[] = array("newsID"=>4, "newsTitle"=>"第4条新闻"); - x2 N/ J$ s& ~) D+ j8 f: c! O $array[] = array("newsID"=>5, "newsTitle"=>"第5条新闻"); ( @- P. Y- n9 ]/ z! }" a1 ] $array[] = array("newsID"=>6, "newsTitle"=>"第6条新闻"); 5 c3 ]8 l& K$ Z5 X' b 2 k9 P( I3 m' s2 g9 K $smarty->assign("newsArray", $array); 9 e0 K8 V0 D- g3 w0 e6 w //编译并显示位于./templates下的index.tpl模板 + N" \ H; m* A/ {7 x7 m: ^ $smarty->display("example.tpl"); ?> |
example.php 输出文件
这里将输出一个数组: 新闻编号:1 ) Q' O2 z0 ]2 j" m% M9 _ 新闻内容:第1条新闻 3 _/ H+ I& Y1 @9 ?/ @ 新闻编号:2 新闻内容:第2条新闻 - G! ]7 Q9 [+ l9 r Y/ @ . Z3 `0 M& r' P2 c& _$ `- y# W 新闻编号:3 新闻内容:第3条新闻 新闻编号:4 ! F2 b5 d8 k0 U6 V: e/ W- P# A. M5 C 新闻内容:第4条新闻 $ [2 \3 L. j6 _) b% ? " s3 o, J/ B* e, z6 o) T% X 新闻编号:5 新闻内容:第5条新闻 ! I# m1 _4 a! e) } . m% [! F4 n& @1 M: i0 I 新闻编号:6 5 @6 N& R/ A. { . `( y$ o# f/ I6 F# o& T/ v 新闻内容:第6条新闻 |
& S$ Z- D9 p. v+ y! d. i
这里的{section}块的对于变量的命名方式感觉有些别扭,不过没关系,你只要记住模板变量使用:
$loopName[name].var这种模式就行了,loopName为loop处赋予的变量名,[name]为name处赋予的字符串,.后为为你要在程序数组中设定要与值相对应的下标名称就行了。* c" g0 z1 \# U+ x h) Q, C
好了,smarty学习指南---程序设计篇就写到这里,对于一般的应用,这些知识已经够用了,其它的一些高级技巧大家请参看手册中的例子,下一节将讲讲
Smarty在实际应用中的例子,将分别以php内置的mysql语句,phplib中的DB类,ADODB,Pear中DB类来分别讲一下各个类库在同
一个例子中的实现。