ecshop模板循环foreach的使用方法及参数详解

更新时间:2016-12-23 点击量:1376

ecshop模板中foreach使用规则,他有以下几个参数 from ,item name iteration index,下面我们一起来看它的用法。

1:foreach使用规则,他有以下几个参数 from ,item name iteration index

 
2:如何使用foreach循环

  如果php要传递一个数组(如:$array)给ecshop的smarty模板.那么我们将通过from=$array 来接受,写法是
{foreach from = $array item = item}

3:ecshop中smarty的下标如何表示,请看下面的例子:
     {foreach from = $array item = item name=name}
     {$smarty.foreach.name.iteration}
     {/foreach}

     这里的iteration就是从1开始的下标,
     如果要从0开始的下标,应该使用{$smarty.foreach.name.index}
 

4:如何判断是否是foreach循环的开始和结束,最后一个元素.
   {if $smarty.foreach.last}表示循环的最后一个元素.{if $smarty.freach.first}表示循环的开始.


  5:如何使用双重循环.

  举例如下:

{foreach from = $test item =item}

 {foreach from=$item.children item=child}
 {$child.name}
 {/foreach}
{/foreach}


上面五条是官方找到的,下面我通过几天的应用,总结出了ec模版中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}里面的内容。

支付宝扫码打赏 微信打赏

如果文章对您有帮助,就打赏一个吧

在线客服

客户服务

热线电话:

0755-36656507 15889489919 服务时间:

周一到周六:9:00-18:00

在线QQ客服

在线微信客服

关于我们 常见问题

支付方式 加盟合作

提交需求
优惠红包 购物车0 反馈留言 返回顶部