程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> PHP模板引擎Smarty內建函數foreach,foreachelse用法分析

PHP模板引擎Smarty內建函數foreach,foreachelse用法分析

編輯:PHP綜合

本文實例講述了PHP模板引擎Smarty內建函數foreach,foreachelse用法。分享給大家供大家參考,具體如下:

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

屬性 類型 是否必須 缺省值 描述 from string Yes n/a 待循環數組的名稱 item string Yes n/a 當前處理元素的變量名稱 key string No n/a

當前處理元素的鍵名

name string No n/a 該循環的名稱,用於訪問該循環
我們通過一個實例,來演示 Smarty 中 {foreach} 和 {foreachelse} 的使用。

實例思路:從數據庫中取出內容,賦給一個數組變量 $_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, '蒼井空', '[email protected]', '2011-10-24 00:00:00'),
(2, '櫻木花道', '[email protected]', '2011-10-24 00:00:00'),
(3, '赤木晴子', '[email protected],cn', '2011-10-24 00:00:00'),
(4, '流川楓', '[email protected]', '0000-00-00 00:00:00'),
(5, '蠟筆小新', '[email protected]', '2011-10-24 00:00:00'),
(6, '金剛葫蘆娃', '[email protected]', '2011-10-24 00:00:00');

init.inc.php (模板初始化文件)

<?php
 define('ROOT_PATH', dirname(__FILE__)); //設置網站根目錄
 require ROOT_PATH.'/libs/Smarty.class.php'; //加載 Smarty 模板引擎
 $_tpl = new Smarty(); //創建一個實例對象
 $_tpl->template_dir = ROOT_PATH.'/tpl/'; //重新指定模板目錄
 $_tpl->compile_dir = ROOT_PATH.'./com/'; //重新指定編譯目錄
 $_tpl->left_delimiter = '<{'; //重新指定左定界符
 $_tpl->right_delimiter = '}>'; //重新指定右定界符
?>

index.php(主文件)

<?php
 require 'init.inc.php'; //引入模板初始化文件
 global $_tpl;
 $_mysqli = new mysqli(); //創建一個 mysqli() 對象
 $_mysqli->connect('localhost','root','數據庫密碼','數據庫名'); //連接數據庫,請您自行設置
 $_mysqli->set_charset('utf8'); //設置編碼
 $_result = $_mysqli->query("select username,email,addTime from user order by id asc");
 $_html = array();
 while (!!$_row=$_result->fetch_assoc()) {
  $_html[] = $_row;
 }
 $_tpl->assign('data',$_html); //把數組分配到模板中
 $_tpl->display('index.tpl'); //引入模板
 $_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(用於顯示循環執行的次數)

更多關於PHP相關內容感興趣的讀者可查看本站專題:《smarty模板入門基礎教程》、《PHP模板技術總結》、《PHP基於pdo操作數據庫技巧總結》、《PHP運算與運算符用法總結》、《PHP網絡編程技巧總結》、《PHP基本語法入門教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家基於smarty模板的PHP程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved