模板引擎是用于把模板文件和数据内容合并在一起的程序,便于网站开发有利于代码分离和维护,了解一个模板最好知道其工作原理,以便于实现一通万通。
模板文件一般是HTML xml js等类型文件,如果不用模板引擎若要把数据显示在网页上,我们需要在php中输出HTML,而使用模板则只要把数据交给模板引擎程序即可,然后告诉它用哪个模板文件,自然就会把数据和页面结合以后返回或输出,模板至少有以下功能1.把数据提供给模板引擎的功能。2.指定模板的功能。3.输出结果的功能。一般来说为了方便程序员们使用模板引擎,开发者都会把它的功能在一定程度上封装起来,封装成一个类,实例化之后得到一个对象,即模板引擎对象,一个对象有其属性和方法,smarty对象的属性和方法在smarty手册上查找,首先说说其方法,assign 把数据提交给模板的方法。没有单独的指定模板文件的方法已经合并到输出的方法中,输出的方法有两个 display 直接输出 fetch 返回合并好的HTML代码,对于输出我们主要用到的是assign 因为我们显示的数据往往是多样性的,可能是一个量,可能是一个数组量也可能是多维数组,在不同的情况下应该如何正确提交给smarty是一个问题,提交后如何对应显示也是个问题,smarty引擎使用的解释方法是先把HTML文件转化为php文件,然后在赋值各个量,并且执行这个php文件,对应不同的数据格式,它有一套固定的书写方式,需要我们用这种书写方式在模板文件上做对应的标记,smarty默认使用的模板标记符是一对{},比如{$a}这个标记等效于echo $a;在php中我们需要有对应的赋值过程,$smarty->assign("a","值");如果我们有多个量进行赋值,一个个这样写就很麻烦,smarty为我们考虑了这一点,例如我们从数据库里读出一个文章,要显示在页面的内容有标题内容作者时间,数据结构大体是这样的
复制代码 代码如下:
array([id]=>1,['title']=>"标题",…);
我们的模板需要有几个对应的标记,例如
复制代码 代码如下:
<h1>{$title}</h1>
<div>{$content}</div>
一个个赋值太麻烦,assign方法支持数组直接赋值,$rows = 从数据库读出的据,
$smarty->assign($rows);smarty就会取数据索引自动一一赋值,但是这个时候为了避免引起变量冲突,我们希望还是直接以数组形式赋值呢,例如
复制代码 代码如下:
$rows = 从数据库读出的据,
$smarty->assign("rows",$rows);
如果此时我们在模板的标记是{$rows} 那输出的时候我们只能看到array 正如php里面直接echo数组一样,在php输出具体量是echo $rows['title'];smarty规定的符号是一个点号,{$rows.title},用这种方式类似于
复制代码 代码如下:
echo $rows['title']
每种模板有其对应的书写规则,接下来如果要显示的是一个文章列表呢,假设mysql给我们返回了10条数据,10条数据都要显示出来,而且他们的索引肯定完全相同,根据编程思路知道结果求过程,假设显示如下
复制代码 代码如下:
<ul>
<li>1111</li>
<li>222</li>
<li>333</li>
<li>4444</li>
</ul>
如果这是我们希望输出的样子
首先这是多个量当然用的是数组了,
复制代码 代码如下:
$list=array();
While($rows=数据){
$list[]=$rows;
}
$smarty->assign("list",$list);
先把数据放到一个数组中再一次性交给smarty,这样一来list变量里面是一个二维数组,如果是我们得到一个这样的二维数组,要把里面所有值显示出来,最好的方法是循环输出,同样smarty为我们提供了循环用的标记,section和 foreach
section标记格式
复制代码 代码如下:
{section name=这次循环的名字 loop=数据量名}
...
{/section}
{section name=i loop=$list}
<li>{$list[i].title}</li>
{/section}
上面的代码看起来很像for循环,但这里的i不是for循环里面的$i 只是这个循环的名字,$list[循环名]这个写法可以每次从数组里得到一个量,正如刚才说的,$list是一个二维数组,$list[i]得到的还是数组。
还有一个写法就是foreach 其语法如下:
复制代码 代码如下:
{foreach key=索引 item=值 from=赋值变量}
{$key}:{$item}<br />
{/foreach}
{foreach item=v from=$list}
<li>{$v.title}</li>
{/foreach}