<div class="main" style="width:590 px;height: 442px;">
<!-- {assign var="i" value="1"} By ym -->
<!-- {foreach from=$pictures item=picture name=no}-->
{if $picture.img_title eq '内饰-前排'}
{assign var=i value="2"}
<img class="ymimg" src="{$picture.img_url}" alt="{$picture.img_desc|escape:html}" title="{$picture.img_desc|escape:html}" style="position: absolute;">
<p class="top-banner"> <span class="title">{$picture.img_title}</span> <span class="desc">{$picture.img_desc|escape:html}</span> </p>
{/if}
<!--{/foreach}-->
{if $i eq "1"}
<img class="ymimg" src="http://www.xxxx.com/images/nopic.gif" alt="暂无图片" title="暂无图片" style="position: absolute;">
{/if}
</div>
另附:
foreach 语法:
假如后台:$smarty->assign('test',$test);
{foreach from=$test item=list name=listone}
<p>{$list}</p>
{/foreach}
from 表示assign过来对应的第一个参数'test',item 就是下面要循环的变量,name是用于访问foreach属性的foreach循环的名称,key当前键名的变量名。
但是我们经常会看到这样的写法:
<!--{foreach from=$test item=list name=listone key=key}-->
<p>{$list}</p>
<!--{/foreach}-->
其实这两种都是一样的,只是加了 <!-- --> 之后,你有没有发现用dreamwearver打开这些语句会以注释一样的灰色显示,这样一眼能看出标签;还有就是调试模版时候,用浏览器打开,加了<!-- -->会注释掉if foreach等这些,而不影响模版原来的样子,更能方便调试模版。
多重循环(两次循环):
<!--{foreach from=$categories item=list}-->
<!--{foreach from=$list.cat item=cat}-->
<a href="{$cat.url}">{$cat.name}</a>
<!--{/foreach}-->
<!--{/foreach}-->
只循环出前两条数据:
<!--{foreach from=$categories item=list name=catlist}-->
<!--{if $smarty.foreach.catlist.iteration<2}-->
<a href="{$list.url}">{$list.name}</a>
<!--{/if}-->
<!--{/foreach}-->
foreachelse :
<!--{foreach from=$categories item=list}-->
<a href="{$list.url}">{$list.name}</a>
<!--{foreachelse}-->
<p>no data</p>
<!--{/foreach}-->
如果{foreach from=$categories item=list}一条数据也没有,那么就执行下面的{foreachelse}{/foreach}里面的内容。