您好,登錄后才能下訂單哦!
小編給大家分享一下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, '蒼井空', '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('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內建函數foreach,foreachelse怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。