|
深入模闆應用:循環處理 |
每個程序都會涉及到循環處理,引入循環到模闆是模闆引擎一個比較有特色的功能。
Ease Template 為了方便應用將在每次循環時增加一個遞增變量$_i ,用戶可以使用此變量來制作循環無數據等提示。
Ease Template提供了兩種循環方式:foreach、while
先來介紹foreach用法(為了方便在Ease Template模闆中的應用,對用法進行了一定的優化)。
test_4.php
-
<?php
- include"./template.ease.php";
- $tpl = new template();
- //參與循環的數組
- $user_list = array(
- array(
- 'name' => 'md-chinese',
- 'pass' => '654321',
- ),
- array(
- 'name' => 'test',
- 'pass' => '123456',
- )
- );
- $tpl->set_file('test_4');
- $tpl->p();
- ?>
test_4.htm
-
循環代碼:
- <!-- $user_list AS $user -->
- ID:{_i}
- 賬號:{user['name']}
- 密碼:{user['pass']}
- <!-- END -->
- 無法得到循環數據代碼:
- <!-- $user_list1 AS $users -->
- ID:{_i}
- 賬號:{users['name']}
- 密碼:{users['pass']}
- <!-- END -->
- <!-- 用於判斷提示檢測的方法$_i==0 -->
- <!-- IF[$_i==0] -->
- <font color="#800000">抱歉,沒有得到循環數據!</font>
- <!-- 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
-
<?php
- include"./template.ease.php";
- //引入數據庫類
- include"./mysql.php";
- $tpl = new template();
- //聲明數據庫
- $db = new Dirver();
- //連接數據庫
- $db->DBLink('localhost','root','','test');
- //索引數據
- $query = $db->query("SELECT * FROM users");
- $tpl->set_file('test_5');
- $tpl->p();
- ?>
此次模闆中與foreach循環一樣也提供了一個沒有數據的循環,將會提示沒有數據效果。
test_5.htm
-
循環代碼:
- <!-- while:$user = $db->fetch_array($query) -->
- ID:{_i}
- 賬號:{user['username']}
- 密碼:{user['password']}
- <!-- END -->
- 無法得到循環數據代碼:
- <!-- while:$users = $db->fetch_array($query1) -->
- ID:{_i}
- 賬號:{users['username']}
- 密碼:{users['password']}
- <!-- END -->
- <!-- 用於判斷提示檢測的方法$_i==0 -->
- <!-- IF[$_i==0] -->
- <font color="#800000">抱歉,沒有得到循環數據!</font>
- <!-- END -->
|
|