本文實例講述了PHP模板引擎Smarty內建函數(shù)foreach,foreachelse用法。分享給大家供大家參考,具體如下:
在 Smarty 模板中,您可以使用 foreach 來重復一個區(qū)塊。而在模板中則需要從 PHP 中分配過來一個數(shù)組。這個數(shù)組可以是多維數(shù)組。Smarty 中 {foreach} 標記和 PHP 中 foreach 相同,不同的是它們的一個在模板文件中使用,一個在 PHP 腳本中使用。因此,語法會不同。但是,它們的作用都是相同的,即遍歷數(shù)組中的內容。與 {foreach} 標記相對的還有一個 {foreachelse} 標記,{foreachelse} 標記的作用是:如果數(shù)組為空,那么就執(zhí)行該標記內的內容。 模板中 {foreach} 和 {/foreach} 必須是成對的出現(xiàn),它有四個參數(shù),其中, from 和 item 兩個參數(shù)是必要的。關于它的參數(shù)請看下面列表:
屬性 | 類型 | 是否必須 | 缺省值 | 描述 |
---|---|---|---|---|
from | string | Yes | n/a | 待循環(huán)數(shù)組的名稱 |
item | string | Yes | n/a | 當前處理元素的變量名稱 |
key | string | No | n/a |
當前處理元素的鍵名 |
name | string | No | n/a | 該循環(huán)的名稱,用于訪問該循環(huán) |
我們通過一個實例,來演示 Smarty 中 {foreach} 和 {foreachelse} 的使用。
實例思路:從數(shù)據(jù)庫中取出內容,賦給一個數(shù)組變量 $_html ,再給這個數(shù)組變量分配給模板,然后在模板中進行該數(shù)組的遍歷
test.sql (使用到的 SQL 數(shù)據(jù))
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
-- -- 表的結構 `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 ; -- -- 轉存表中的數(shù)據(jù) `user` -- INSERT INTO ` user ` (`id`, `username`, `email`, `addTime`) VALUES |
init.inc.php (模板初始化文件)
1
2
3
4
5
6
7
8
9
|
<?php define( 'ROOT_PATH' , dirname( __FILE__ )); //設置網(wǎng)站根目錄 require ROOT_PATH. '/libs/Smarty.class.php' ; //加載 Smarty 模板引擎 $_tpl = new Smarty(); //創(chuàng)建一個實例對象 $_tpl ->template_dir = ROOT_PATH. '/tpl/' ; //重新指定模板目錄 $_tpl ->compile_dir = ROOT_PATH. './com/' ; //重新指定編譯目錄 $_tpl ->left_delimiter = '<{' ; //重新指定左定界符 $_tpl ->right_delimiter = '}>' ; //重新指定右定界符 ?> |
index.php(主文件)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<?php require 'init.inc.php' ; //引入模板初始化文件 global $_tpl ; $_mysqli = new mysqli(); //創(chuàng)建一個 mysqli() 對象 $_mysqli ->connect( 'localhost' , 'root' , '數(shù)據(jù)庫密碼' , '數(shù)據(jù)庫名' ); //連接數(shù)據(jù)庫,請您自行設置 $_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 ); //把數(shù)組分配到模板中 $_tpl ->display( 'index.tpl' ); //引入模板 $_mysqli ->close(); //關閉數(shù)據(jù)庫,釋放資源 ?> |
tpl/index.tpl(主文件 index.php 的模板文件)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
<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 循環(huán)分配過來的數(shù)組有幾行數(shù)據(jù) --> <!-- 在此,我們做幾個保留變量 $smarty . foreach 的操作 --> <!-- 當數(shù)據(jù)顯示第一條的時候,第一行的表格背景為黃色,使用屬性:first --> <!-- 當數(shù)據(jù)顯示最后一條的時候,最后一行的表格背景為藍色,使用屬性:last --> <!-- 顯示下分配過來的數(shù)組的總個數(shù),使用屬性: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 開始,每執(zhí)行一次增加 1 --> <{ foreach from= $row item= "col" name= "lsin" }> <!-- 這個 foreach 循環(huán)數(shù)組內的內容,顯示在表格的<td></td>標簽里 --> <td><{ $col }></td> <{/ foreach }> </tr> <{foreachelse}> <!-- 如果分配過來的數(shù)組中沒有數(shù)據(jù),那么就執(zhí)行下面的操作! --> <tr> <td>對不起!暫時沒有數(shù)據(jù)。</td> </tr> <{/ foreach }> <tr> <td colspan= "4" align= "center" >分配數(shù)組的總記錄數(shù)為:<{ $smarty . foreach .ls.total}>條</td> </tr> </table> </body> </html> |
執(zhí)行結果:
最后總結下,主文件 index.php 中傳遞過去的數(shù)組 $_html 為二維數(shù)組。保留變量 $smarty.foreach 的使用都是基于 {foreach} 標記中的 name 屬性,使用到的保留變量屬性有:first(首條記錄)、last(末條記錄)、iteration(總是從 1 開始,每執(zhí)行一次增加 1)、total(用于顯示循環(huán)執(zhí)行的次數(shù))
希望本文所述對大家基于smarty模板的PHP程序設計有所幫助。