好文档就是一把金锄头!
欢迎来到金锄头文库![会员中心]
电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本

Smarty快速上手教程.docx

18页
  • 卖家[上传人]:平***
  • 文档编号:14219683
  • 上传时间:2017-10-28
  • 文档格式:DOCX
  • 文档大小:21.39KB
  • / 18 举报 版权申诉 马上下载
  • 文本预览
  • 下载提示
  • 常见问题
    • Smarty 学习教程一:smarty 的程序设计部分:下载 Smarty文件放到你们站点中index.phpPHP代码:templates("./templates"); //设置模板目录$smarty->templates_c("./templates_c"); //设置编译目录$smarty->cache("./cache"); //缓存目录$smarty->cache_lifetime = 0; //缓存时间$smarty->caching = true; //缓存方式$smarty->left_delimiter = "{#"; $smarty->right_delimiter = "#}"; 指明在查找模板变量时的右分割符$smarty->assign("name", "zaocha"); //进行模板变量替换$smarty->display("index.htm"); //编译并显示位于./templates下的 index.htm模板?>二:解释 smarty的程序我们可以看到,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是一种编译型模板语言,而这个目录,就是它编译模板的目录,要注意,如果站点位于 linux服务器上,请确保teamplates_c里定义的这个目录具有可写可读权限,默认情况下它的编译目录是当前目录下的 templates_c,出于同样的理由我们将其明确的写出来。

      6:$smarty->left_delimiter 与$smarty->right_delimiter:指明在查找模板变量时的左右分割符默认情况下为"{"与"}",但在实际中因为我们要在模板中使用,Script 中的函数定义难免会使用{},虽然它有自己的解决办法,但习惯上我们将它重新定义为"{#"与"#}"或是""或其它标志符,注意,如果在这里定义了左右分割符后,在模板文件中相应的要使每一个变量使用与定义相同的符号,例如在这里指定为"",htm 模板中也要相应的将{$name}变成,这样程序才可以正确的找到模板变量7:$smarty->cache("./cache"):告诉 Smarty输出的模板文件缓存的位置上一篇我们知道 Smarty最大的优点在于它可以缓存,这里就是设置缓存的目录默认情况下为当前目录下的 cache目录,与 templates_c目录相当,在linux系统中我们要确保它的可读可写性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", "zaocha"):该数的原型为 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}用来当程序中传递过来的数组为空时的处理,下面是一个简单的例子:模板文件:example.htmforeach 输出一个“二维关联数组”的数据:{#foreach item=new from=$news#}新闻编号:{#$new.id#}新闻内容:{#$new.title#}{#foreachelse#}数据库中没有新闻输出!{#/foreach#}{foreach from=$newsArray item=newsID}新闻编号:{$newsID}新闻内容:{$newsTitle}{foreachelse}对不起,数据库中没有新闻输出!{/foreach}这是一个错误的不显示数据,本文做了更正程序文件:example.phptemplates("./templates");$smarty->templates_c("./templates_c");$smarty->cache("./cache");$smarty->cache_lifetime = 0;$smarty->caching = true;$smarty->left_delimiter = "{#";$smarty->right_delimiter = "#}";$array[] = array("newsID"=>1, "newsTitle"=>"第 1条新闻");$array[] = array("newsID"=>2, "newsTitle"=>"第 2条新闻");$array[] = array("newsID"=>3, "newsTitle"=>"第 3条新闻");$array[] = array("newsID"=>4, "newsTitle"=>"第 4条新闻");$array[] = array("newsID"=>5, "newsTitle"=>"第 5条新闻");$array[] = array("newsID"=>6, "newsTitle"=>"第 6条新闻");//这是一个二维关联数组$smarty->assign("newsArray", $array);//编译并显示位于./templates 下的 index.htm模板$smarty->display("example.htm");?>输入结果:example.php这里将输出一个数组:新闻编号:1 新闻内容:第 1条新闻新闻编号:2新闻内容:第 2条新闻新闻编号:3新闻内容:第 3条新闻新闻编号:4新闻内容:第 4条新闻新闻编号:5新闻内容:第 5条新闻新闻编号:6新闻内容:第 6条新闻foreach还可以用 foreachelse来匹配,用 foreachelse来表示当传递给 foreach的数组为空值时程序要执行的操作,具体的使用方法,请参考手册的说明。

      2. section:section的产生是为解决 foreach的不足的,与 foreach一样,它用于设计模板内的循环块,它较为复杂,可极大程序上满足程序需要,所以在程序中我习惯使用它而不使用 foreach,基本原形为:{section name = name loop = $varName[, start = $start, step = $step, max = $max, show = true]}name: section的名称,不用加$$loop: 要循环的变量,在程序中要使用 assign对这个变量进行操作start: 开始循环的下标,循环下标默认由 0开始$step: 每次循环时下标的增数$max: 最大循环下标$show: boolean类型,决定是否对这个块进行显示,默认为 true这里有个名词需要说明:循环下标:实际它的英文名称为 index,是索引的意思,这里我将它译成"下标",主要是为了好理解它表示在显示这个循环块时当前的循环索引,默 认从 0开始,受$start 的影响,如果将$start设为 5,它也将从 5开始计数,在模板设计部分我们使用过它,这是当前{section}的一个属 性,调用方式为Smarty.section.sectionName.index,这里的 sectionName指的是函数原型中的 name属性。

      {section}块具有的属性值,分别为:1. index: 上边我们介绍的"循环下标",默认为 02. index_prev: 当前下标的前一个值,默认为-13. index_next: 当前下标的下一个值,默认为 14. first: 是否为第一下循环5. last: 是否为最后一个循环6. iteration: 循环次数7. rownum: 当前的行号,iteration 的另一个别名8. loop: 最后一个循环号,可用在 section块后统计 section的循环次数9. total: 循环次数,可用在 section块后统计循环次数10. show: 在函数的声明中有它,用于判断 section是否显示它们的具体属性大家可以参考手册,在程序中可灵活使用它的这些属性,模板部分我就使用过 index属性,大家可以回过头去看看同样,{section}也可以配合使用{sectionelse},用来表示传入的数组变量为空时对模板进行的处理我们把上边的那个例子使用{section}来替代{foreach}来实现现样的功能,注意,在这个例子中我只将 tpl模板中的{foreach}用{sectio。

      点击阅读更多内容
      关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
      手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
      ©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.