{foreach}是我们在使用smarty模板中经常使用的方法, 经常用于遍历数组或者对象数据集合并输出数据集合, 以下smarty手册是对{foreach}方法详细说明:
Attribute Name属性名称 |
Type类型 |
Required必要 |
Default默认值 |
Description描述 |
from |
array数组 |
Yes必要 |
n/a |
The array you are looping through |
item |
string字符串 |
Yes必要 |
n/a |
The name of the variable that is the current element |
key |
string字符串 |
No可选 |
n/a |
The name of the variable that is the current key |
name |
string字符 |
No可选 |
n/a |
The name of the foreach loop for accessing foreach properties |
使用范例:
Example 7-5. The item attribute
例 7-5. item属性
- <?php
- $arr = array(1000, 1001, 1002);
- $smarty->assign('myArray', $arr);
- ?>
Template to output $myArray in an un-ordered list
用模板以无序列表输出$myArray
- <ul>
- {foreach from=$myArray item=foo}
- <li>{$foo}</li>
- {/foreach}
- </ul>
上例将输出:
- <ul>
- <li>1000</li>
- <li>1001</li>
- <li>1002</li>
- </ul>
Example 7-6. Demonstrates the item and key attributes
例 7-6. 演示item和key属性
- <?php
- $arr = array(9 => 'Tennis', 3 => 'Swimming', 8 => 'Coding');
- $smarty->assign('myArray', $arr);
- ?>
Template to output $myArray as key/val pair, like PHP's foreach.
用模板按键名/键值对的形式输出$myArray, 类似于PHP的foreach。
- <ul>
- {foreach from=$myArray key=k item=v}
- <li>{$k}: {$v}</li>
- {/foreach}
- </ul>
The above example will output:
上例将输出:
- <ul>
- <li>9: Tennis</li>
- <li>3: Swimming</li>
- <li>8: Coding</li>
- </ul>
Example 7-7. {foreach} with associative item attribute
例 7-7. {foreach}的item属性是关联数组
- <?php
- $items_list = array(23 => array('no' => 2456, 'label' => 'Salad'),
- 96 => array('no' => 4889, 'label' => 'Cream')
- );
- $smarty->assign('items', $items_list);
- ?>
模板中,url通过$myId输出$items
- <ul>
- {foreach from=$items key=myId item=i}
- <li><a href="item.php?id={$myId}">{$i.no}: {$i.label}</li>
- {/foreach}
- </ul>
上例将输出:
- <ul>
- <li><a href="item.php?id=23">2456: Salad</li>
- <li><a href="item.php?id=96">4889: Cream</li>
- </ul>
Example 7-8. {foreach} with nested item and key
例 7-8. {foreach}使用嵌套的item和key
Assign an array to Smarty, the key contains the key for each looped value.
向Smarty设置一个数组,对于每个键名对应的每个循环值都包括键。
- <?php
- $smarty->assign('contacts', array(
- array('phone' => '1',
- 'fax' => '2',
- 'cell' => '3'),
- array('phone' => '555-4444',
- 'fax' => '555-3333',
- 'cell' => '760-1234')
- ));
- ?>
The template to output $contact.
用于输出$contact的模板。
- {foreach name=outer item=contact from=$contacts}
- <hr />
- {foreach key=key item=item from=$contact}
- {$key}: {$item}<br />
- {/foreach}
- {/foreach}
上例将输出:
- <hr />
- phone: 1<br />
- fax: 2<br />
- cell: 3<br />
- <hr />
- phone: 555-4444<br />
- fax: 555-3333<br />
- cell: 760-1234<br />
Example 7-9. Database example with {foreachelse}
例 7-9. 使用{foreachelse}的数据库示例
一个数据库(例如PEAR或ADODB)的搜索脚本示例,
- <?php
- $search_condition = "where name like '$foo%' ";
- $sql = 'select contact_id, name, nick from contacts '.$search_condition.' order by name';
- $smarty->assign('results', $db->getAssoc($sql) );
- ?>
借助{foreachelse}标记在没有结果时模板输出"None found"字样。
- {foreach key=cid item=con from=$results}
- <a href="contact.php?contact_id={$cid}">{$con.name} - {$con.nick}</a><br />
- {foreachelse}
- No items were found in the search
- {/foreach}
.index
.index包含当前数组索引,从零开始。
Example 7-10. index example
例 7-10. index示例
- {* The header block is output every five rows *}
- {* 每五行输出一次头部区块 *}
- <table>
- {foreach from=$items key=myId item=i name=foo}
- {if $smarty.foreach.foo.index % 5 == 0}
- <tr><th>Title</th></tr>
- {/if}
- <tr><td>{$i.label}</td></tr>
- {/foreach}
- </table>
.iteration
iteration包含当前循环次数,与index不同,从1开始,每次循环增长1。
Example 7-11. iteration and index example
例 7-11. iteration和index示例
- {* this will output 0|1, 1|2, 2|3, ... etc *}
- {* 该例将输出0|1, 1|2, 2|3, ... 等等 *}
- {foreach from=$myArray item=i name=foo}
- {$smarty.foreach.foo.index}|{$smarty.foreach.foo.iteration},
- {/foreach}
.first
first在当前{foreach}循环处于初始位置时值为TRUE。
Example 7-12. first property example
例 7-12. first属性示例
- {* show LATEST on the first item, otherwise the id *}
- {* 对于第一个条目显示LATEST而不是id *}
- <table>
- {foreach from=$items key=myId item=i name=foo}
- <tr>
- <td>{if $smarty.foreach.foo.first}LATEST{else}{$myId}{/if}</td>
- <td>{$i.label}</td>
- </tr>
- {/foreach}
- </table>
.last
last在当前{foreach}循环处于最终位置是值为TRUE。
Example 7-13. last property example
例 7-13. last属性示例
- {* Add horizontal rule at end of list *}
- {* 在列表结束时增加一个水平标记 *})
- {foreach from=$items key=part_id item=prod name=products}
- <a href="#{$part_id}">{$prod}</a>{if $smarty.foreach.products.last}<hr>{else},{/if}
- {foreachelse}
- ... content ...
- {/foreach}
.show
show是{foreach}的参数. show是一个布尔值。如果值为FALSE,{foreach}将不被显示。如果有对应的{foreachelse},将被显示。
本文出自 “开发随笔” 博客,谢绝转载!