首頁  >  文章  >  後端開發  >  Smarty模板中的foreach,foreachelse的用法程式碼實例

Smarty模板中的foreach,foreachelse的用法程式碼實例

伊谢尔伦
伊谢尔伦原創
2017-06-23 14:46:241364瀏覽

主要介紹了PHP模板引擎Smarty內建函數foreach,foreachelse用法,結合實例形式分析了foreach,foreachelse的功能與具體使用技巧,具體如下:

在Smarty 模板中,您可以使用foreach 來重複一個區塊。而在模板中則需要從 PHP 分配過來一個陣列。這個數組可以是多維數組。 Smarty 中 {foreach} 標記和 PHP 中 foreach 相同,不同的是它們的一個在模板檔案中使用,一個在 PHP 腳本中使用。因此,語法會不同。但是,它們的作用都是相同的,即遍歷數組中的內容。與 {foreach} 標記相對的還有一個 {foreachelse} 標記,{foreachelse} 標記的作用是:如果數組為空,那麼就執行該標記內的內容。 模板中 {foreach} 和 {/foreach} 必須是成對的出現,它有四個參數,其中, from 和 item 兩個參數是必要的。關於它的參數請看下面列表:

待循環陣列的名稱#itemstringYes目前處理元素的變數名稱keystringNonamestringNo我們透過一個實例,來示範Smarty 中{foreach} 和{foreachelse} 的使用。
屬性 #類型 是否必須 預設值 描述
from #string Yes # #n/a
n/a
n/a #目前處理元素的鍵名稱

#n/a##該循環的名稱,用於存取該循環

實例思路:從資料庫中取出內容,賦給一個數組變數$_html ,再給這個數組變數分配給模板,然後在模板中進行該

數組的遍歷

#test.sql (使用到的SQL 資料)

--
-- 表的结构 `user`
--
CREATE TABLE IF NOT EXISTS `user` (
 `id` mediumint(8) unsigned NOT NULL auto_increment,
 `username` varchar(50) NOT NULL,
 `email` varchar(50) NOT NULL,
 `addTime` datetime NOT NULL default '0000-00-00 00:00:00',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=7 ;
--
-- 转存表中的数据 `user`
--
INSERT INTO `user` (`id`, `username`, `email`, `addTime`) VALUES
(1, '苍井空', 'canjingkong@sina.com.cn', '2011-10-24 00:00:00'),
(2, '樱木花道', 'ymhd@163.com', '2011-10-24 00:00:00'),
(3, '赤木晴子', 'chimiqingzi@yahoo.com,cn', '2011-10-24 00:00:00'),
(4, '流川枫', 'lcfeng@sina.com', '0000-00-00 00:00:00'),
(5, '蜡笔小新', 'labixiaoxin@sina.com', '2011-10-24 00:00:00'),
(6, '金刚葫芦娃', 'jghlw@sina.com', '2011-10-24 00:00:00');

init.inc.php (模板初始化檔)

<?php
 define(&#39;ROOT_PATH&#39;, dirname(FILE)); //设置网站根目录
 require ROOT_PATH.&#39;/libs/Smarty.class.php&#39;; //加载 Smarty 模板引擎
 $_tpl = new Smarty(); //创建一个实例对象
 $_tpl->template_dir = ROOT_PATH.&#39;/tpl/&#39;; //重新指定模板目录
 $_tpl->compile_dir = ROOT_PATH.&#39;./com/&#39;; //重新指定编译目录
 $_tpl->left_delimiter = &#39;<{&#39;; //重新指定左定界符
 $_tpl->right_delimiter = &#39;}>&#39;; //重新指定右定界符
?>

index.php(主檔案)

<?php
 require &#39;init.inc.php&#39;; //引入模板初始化文件
 global $_tpl;
 $_mysqli = new mysqli(); //创建一个 mysqli() 对象
 $_mysqli->connect(&#39;localhost&#39;,&#39;root&#39;,&#39;数据库密码&#39;,&#39;数据库名&#39;); //连接数据库,请您自行设置
 $_mysqli->set_charset(&#39;utf8&#39;); //设置编码
 $_result = $_mysqli->query("select username,email,addTime from user order by id asc");
 $_html = array();
 while (!!$_row=$_result->fetch_assoc()) {
  $_html[] = $_row;
 }
 $_tpl->assign(&#39;data&#39;,$_html); //把数组分配到模板中
 $_tpl->display(&#39;index.tpl&#39;); //引入模板
 $_mysqli->close(); //关闭数据库,释放资源
?>

tpl/index.tpl(主檔案index.php 的範本檔案)

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>foreach,foreachelse</title>
</head>
<body>
 <table align="center" border="1" width="800">
  <{foreach from=$data item="row" name="ls"}> <!-- 这个foreach 循环分配过来的数组有几行数据 -->
   <!-- 在此,我们做几个保留变量 $smarty.foreach 的操作 -->
   <!-- 当数据显示第一条的时候,第一行的表格背景为黄色,使用属性:first -->
   <!-- 当数据显示最后一条的时候,最后一行的表格背景为蓝色,使用属性:last -->
   <!-- 显示下分配过来的数组的总个数,使用属性:total -->
   <{if $smarty.foreach.ls.first}>
   <tr bgcolor="#FFFF00"> <!-- 第一行背景为黄色 -->
   <{elseif $smarty.foreach.ls.last}>
   <tr bgcolor="#0000FF"> <!-- 最后一行背景为蓝色 -->
   <{else}>
   <tr>
   <{/if}>
    <td><{$smarty.foreach.ls.iteration}></td><!-- 注意:这里是保留变量 $smarty.foreach 的使用,iteration:总是从 1 开始,每执行一次增加 1 -->
    <{foreach from=$row item="col" name="lsin"}> <!-- 这个foreach 循环数组内的内容,显示在表格的<td></td>标签里 -->
     <td><{$col}></td>
    <{/foreach}>
   </tr>
  <{foreachelse}> <!-- 如果分配过来的数组中没有数据,那么就执行下面的操作! -->
   <tr>
    <td>对不起!暂时没有数据。</td>
   </tr>
  <{/foreach}>
  <tr>
   <td colspan="4" align="center">分配数组的总记录数为:<{$smarty.foreach.ls.total}>条</td>
  </tr>
 </table>
</body>
</html>

執行結果:

最後總結下,主檔案index.php中傳遞過去的陣列$_html 為

二維陣列

。保留變數$smarty.foreach 的使用都是基於{foreach} 標記中的name 屬性,使用到的保留變數屬性有:first(首筆記錄)、last(最後筆記錄)、iteration(總是從1 開始,每執行一次增加1)、total(用來顯示循環執行的次數)

以上是Smarty模板中的foreach,foreachelse的用法程式碼實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn