Ease Template Manual Version:E3
功能列表:
選擇最合適的模闆 ET
ET 無與倫比的優勢
ET學習入門實例
深入模闆應用:變量
深入模闆應用:路徑解析
深入模闆應用:邏輯判斷
深入模闆應用:循環處理
深入模闆應用:嵌套循環
深入模闆應用:特殊循環
深入模闆應用:彌補函數
深入模闆應用:連載執行
深入模闆應用:中層編譯
深入模闆應用:內部引用
深入模闆應用:引用PHP
深入模闆應用:多語言篇
深入模闆應用:調試平臺
下載ET
版本歷史
聯繫作者
ET 經典案例
深入模闆應用:循環處理
每個程序都會涉及到循環處理,引入循環到模闆是模闆引擎一個比較有特色的功能。

Ease Template 為了方便應用將在每次循環時增加一個遞增變量$_i ,用戶可以使用此變量來制作循環無數據等提示。

Ease Template提供了兩種循環方式:foreach、while

先來介紹foreach用法(為了方便在Ease Template模闆中的應用,對用法進行了一定的優化)。

test_4.php
  1. <?php  
  2. include"./template.ease.php";  
  3. $tpl = new template();  
  4. //參與循環的數組  
  5. $user_list = array(  
  6.   array(  
  7.     'name'  => 'md-chinese',  
  8.     'pass'  => '654321',  
  9.   ),  
  10.   array(  
  11.     'name'  => 'test',  
  12.     'pass'  => '123456',  
  13.   )  
  14. );  
  15. $tpl->set_file('test_4');  
  16. $tpl->p();  
  17. ?>

test_4.htm
  1. 循環代碼:  
  2. <!-- $user_list AS $user -->  
  3.   ID:{_i}   
  4.   賬號:{user['name']}  
  5.   密碼:{user['pass']}  
  6. <!-- END -->  
  7. 無法得到循環數據代碼:  
  8. <!-- $user_list1 AS $users -->  
  9.   ID:{_i}   
  10.   賬號:{users['name']}  
  11.   密碼:{users['pass']}  
  12. <!-- END -->  
  13. <!-- 用於判斷提示檢測的方法$_i==0 -->  
  14. <!-- IF[$_i==0] -->  
  15. <font color="#800000">抱歉,沒有得到循環數據!</font>  
  16. <!-- END -->


現在我們進入更復雜的循環操作:while在模闆中對數據庫的操作。如果將數據庫對象引入模闆則不用在循環後得到數組再賦值給模闆,節省了大量時間以及循環次數。

測試數據庫內容:
[text character set utf8]
CREATE TABLE `users` (
`uid` INT( 3 ) NOT NULL AUTO_INCREMENT PRIMARY KEY ,
`username` VARCHAR( 64 ) NOT NULL ,
`password` VARCHAR( 32 ) NOT NULL
) TYPE = MyISAM ;

INSERT INTO `users` (`uid`, `username`, `password`) VALUES (1, 'md-chinese', '123456'),
(2, 'ease template', 'systn');
[/text character set utf8]

這裡為了體現數據庫操作效果,我們載入一個簡單的數據庫類,連接本地數據庫,並且連接test庫表。

test_5.php
  1. <?php  
  2. include"./template.ease.php";  
  3. //引入數據庫類  
  4. include"./mysql.php";  
  5. $tpl = new template();  
  6. //聲明數據庫  
  7. $db = new Dirver();  
  8. //連接數據庫  
  9. $db->DBLink('localhost','root','','test');  
  10. //索引數據  
  11. $query $db->query("SELECT * FROM users");  
  12. $tpl->set_file('test_5');  
  13. $tpl->p();  
  14. ?>


此次模闆中與foreach循環一樣也提供了一個沒有數據的循環,將會提示沒有數據效果。

test_5.htm
  1. 循環代碼:  
  2. <!-- while:$user = $db->fetch_array($query) -->  
  3.   ID:{_i}   
  4.   賬號:{user['username']}  
  5.   密碼:{user['password']}  
  6. <!-- END -->  
  7. 無法得到循環數據代碼:  
  8. <!-- while:$users = $db->fetch_array($query1) -->  
  9.   ID:{_i}   
  10.   賬號:{users['username']}  
  11.   密碼:{users['password']}  
  12. <!-- END -->  
  13. <!-- 用於判斷提示檢測的方法$_i==0 -->  
  14. <!-- IF[$_i==0] -->  
  15. <font color="#800000">抱歉,沒有得到循環數據!</font>  
  16. <!-- END -->
我要啦免费统计