PHP模板引擎Smarty內(nèi)建函數(shù)foreach,foreachelse用法分析
本文實(shí)例講述了PHP模板引擎Smarty內(nèi)建函數(shù)foreach,foreachelse用法。分享給大家供大家參考,具體如下:
在 Smarty 模板中,您可以使用 foreach 來(lái)重復(fù)一個(gè)區(qū)塊。而在模板中則需要從 PHP 中分配過(guò)來(lái)一個(gè)數(shù)組。這個(gè)數(shù)組可以是多維數(shù)組。Smarty 中 {foreach} 標(biāo)記和 PHP 中 foreach 相同,不同的是它們的一個(gè)在模板文件中使用,一個(gè)在 PHP 腳本中使用。因此,語(yǔ)法會(huì)不同。但是,它們的作用都是相同的,即遍歷數(shù)組中的內(nèi)容。與 {foreach} 標(biāo)記相對(duì)的還有一個(gè) {foreachelse} 標(biāo)記,{foreachelse} 標(biāo)記的作用是:如果數(shù)組為空,那么就執(zhí)行該標(biāo)記內(nèi)的內(nèi)容。 模板中 {foreach} 和 {/foreach} 必須是成對(duì)的出現(xiàn),它有四個(gè)參數(shù),其中, from 和 item 兩個(gè)參數(shù)是必要的。關(guān)于它的參數(shù)請(qǐng)看下面列表:
| 屬性 | 類型 | 是否必須 | 缺省值 | 描述 |
|---|---|---|---|---|
| from | string | Yes | n/a | 待循環(huán)數(shù)組的名稱 |
| item | string | Yes | n/a | 當(dāng)前處理元素的變量名稱 |
| key | string | No | n/a |
當(dāng)前處理元素的鍵名 |
| name | string | No | n/a | 該循環(huán)的名稱,用于訪問(wèn)該循環(huán) |
我們通過(guò)一個(gè)實(shí)例,來(lái)演示 Smarty 中 {foreach} 和 {foreachelse} 的使用。
實(shí)例思路:從數(shù)據(jù)庫(kù)中取出內(nèi)容,賦給一個(gè)數(shù)組變量 $_html ,再給這個(gè)數(shù)組變量分配給模板,然后在模板中進(jìn)行該數(shù)組的遍歷
test.sql (使用到的 SQL 數(shù)據(jù))
-- -- 表的結(jié)構(gòu) `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 ; -- -- 轉(zhuǎn)存表中的數(shù)據(jù) `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__)); //設(shè)置網(wǎng)站根目錄
require ROOT_PATH.'/libs/Smarty.class.php'; //加載 Smarty 模板引擎
$_tpl = new Smarty(); //創(chuàng)建一個(gè)實(shí)例對(duì)象
$_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(); //創(chuàng)建一個(gè) mysqli() 對(duì)象
$_mysqli->connect('localhost','root','數(shù)據(jù)庫(kù)密碼','數(shù)據(jù)庫(kù)名'); //連接數(shù)據(jù)庫(kù),請(qǐng)您自行設(shè)置
$_mysqli->set_charset('utf8'); //設(shè)置編碼
$_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(); //關(guān)閉數(shù)據(jù)庫(kù),釋放資源
?>
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"}> <!-- 這個(gè)foreach 循環(huán)分配過(guò)來(lái)的數(shù)組有幾行數(shù)據(jù) -->
<!-- 在此,我們做幾個(gè)保留變量 $smarty.foreach 的操作 -->
<!-- 當(dāng)數(shù)據(jù)顯示第一條的時(shí)候,第一行的表格背景為黃色,使用屬性:first -->
<!-- 當(dāng)數(shù)據(jù)顯示最后一條的時(shí)候,最后一行的表格背景為藍(lán)色,使用屬性:last -->
<!-- 顯示下分配過(guò)來(lái)的數(shù)組的總個(gè)數(shù),使用屬性:total -->
<{if $smarty.foreach.ls.first}>
<tr bgcolor="#FFFF00"> <!-- 第一行背景為黃色 -->
<{elseif $smarty.foreach.ls.last}>
<tr bgcolor="#0000FF"> <!-- 最后一行背景為藍(lán)色 -->
<{else}>
<tr>
<{/if}>
<td><{$smarty.foreach.ls.iteration}></td><!-- 注意:這里是保留變量 $smarty.foreach 的使用,iteration:總是從 1 開(kāi)始,每執(zhí)行一次增加 1 -->
<{foreach from=$row item="col" name="lsin"}> <!-- 這個(gè)foreach 循環(huán)數(shù)組內(nèi)的內(nèi)容,顯示在表格的<td></td>標(biāo)簽里 -->
<td><{$col}></td>
<{/foreach}>
</tr>
<{foreachelse}> <!-- 如果分配過(guò)來(lái)的數(shù)組中沒(méi)有數(shù)據(jù),那么就執(zhí)行下面的操作! -->
<tr>
<td>對(duì)不起!暫時(shí)沒(méi)有數(shù)據(jù)。</td>
</tr>
<{/foreach}>
<tr>
<td colspan="4" align="center">分配數(shù)組的總記錄數(shù)為:<{$smarty.foreach.ls.total}>條</td>
</tr>
</table>
</body>
</html>
執(zhí)行結(jié)果:

最后總結(jié)下,主文件 index.php 中傳遞過(guò)去的數(shù)組 $_html 為二維數(shù)組。保留變量 $smarty.foreach 的使用都是基于 {foreach} 標(biāo)記中的 name 屬性,使用到的保留變量屬性有:first(首條記錄)、last(末條記錄)、iteration(總是從 1 開(kāi)始,每執(zhí)行一次增加 1)、total(用于顯示循環(huán)執(zhí)行的次數(shù))
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《smarty模板入門基礎(chǔ)教程》、《PHP模板技術(shù)總結(jié)》、《PHP基于pdo操作數(shù)據(jù)庫(kù)技巧總結(jié)》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語(yǔ)法入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家基于smarty模板的PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP設(shè)計(jì)模式(九)外觀模式Facade實(shí)例詳解【結(jié)構(gòu)型】
這篇文章主要介紹了PHP設(shè)計(jì)模式:外觀模式Facade,結(jié)合實(shí)例形式詳細(xì)分析了PHP外觀模式Facade相關(guān)概念、功能、原理、用法與操作注意事項(xiàng),需要的朋友可以參考下2020-05-05
Yii編程開(kāi)發(fā)常見(jiàn)調(diào)用技巧集錦
這篇文章主要介紹了Yii編程開(kāi)發(fā)常見(jiàn)調(diào)用技巧,涉及Yii針對(duì)cookie、數(shù)據(jù)庫(kù)、URL、項(xiàng)目等相關(guān)操作技巧,需要的朋友可以參考下2016-07-07
PHP使用openssl擴(kuò)展實(shí)現(xiàn)加解密方法示例
這篇文章主要介紹了PHP使用openssl擴(kuò)展實(shí)現(xiàn)加解密方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
php使用get和post傳遞數(shù)據(jù)出現(xiàn)414?Request-URI?Too?Large的原因分析及解決方案
Request-URI Too Large(請(qǐng)求URI過(guò)長(zhǎng))是一個(gè)HTTP錯(cuò)誤狀態(tài)碼,表示所發(fā)送的HTTP請(qǐng)求中的URI(統(tǒng)一資源標(biāo)識(shí)符)長(zhǎng)度超過(guò)了服務(wù)器能夠處理的限制,這篇文章主要介紹了php使用get和post傳遞數(shù)據(jù)出現(xiàn)414?Request-URI Too?Large的解決方案,需要的朋友可以參考下2023-08-08
Yii2表單事件之Ajax提交實(shí)現(xiàn)方法
這篇文章主要介紹了Yii2表單事件之Ajax提交實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了Yii2框架中ajax提交的具體實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-05-05
Yii2框架數(shù)據(jù)庫(kù)簡(jiǎn)單的增刪改查語(yǔ)法小結(jié)
這篇文章主要介紹了Yii2框架數(shù)據(jù)庫(kù)簡(jiǎn)單的增刪改查語(yǔ)法小結(jié),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08
PHP無(wú)限循環(huán)獲取MySQL中的數(shù)據(jù)實(shí)例代碼
最近公司有個(gè)需求需要從MySQL獲取數(shù)據(jù),然后在頁(yè)面上無(wú)線循環(huán)的翻頁(yè)展示.其實(shí)這個(gè)功能可以通過(guò)jq實(shí)現(xiàn),也可以通過(guò)php+mysql實(shí)現(xiàn),下面小編給大家分享基于PHP無(wú)限循環(huán)獲取MySQL中的數(shù)據(jù)實(shí)現(xiàn)方法,感興趣的朋友一起看看吧2017-08-08

