| 
 如果你学过Asp.net,你一定知道它里面有一个叫datalist之类自带的分页功能十分强大,这里的这个类就模拟了一部份这个功能,我敢用“强大”来定义它,是因为作为一个通用的页类,这个类真正做到了“通用”。废话少说,马上介绍一下是如何使用的。
 1、先新建一个用于测试的表
 
 
    
        
            | 以下为引用的内容: CREATE TABLE `test` (
 `aa` INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
 `bb` VARCHAR(50) NOT NULL,
 `cc` VARCHAR(50) NOT NULL,
 `tt` INT DEFAULT '0' NOT NULL
 );
 |  2、制作一个模板文件,保存为:test.htm
 
 
    
        3、编写调用这个类的代码
            | 以下为引用的内容: www.phperz.com {dede:page pagesize=15/}
 <table width='100%' border='0' cellpadding='1' cellspacing='1' bgcolor='#CCCCCC'>
 <tr bgcolor='#F8FFEE' align='center'>
 <td width='10%'>aa</td>
 <td width='30%'>bb</td>
 <td width='30%'>cc</td>
 <td width='30%'>tt</td>
 </tr>
 {dede:datalist}
 <tr bgcolor='#FFFFFF' align='center'>
 <td>[field:aa/]</td>
 <td>[field:bb/]</td>
 <td>[field:cc/]</td>
 <td>[field:tt function='date("Y-m-d H-i-s","@me")'/]</td>
 </tr>
 {/dede}
 <tr bgcolor='#F8FFEE'>
 <td colspan='4'>
 {dede:pagelist listsize=3/}
 </td>
 </tr>
 </table>
 
 |  数据库的连接信息均在config_base.php这个文件是设定
 phperz.com showtable.php
 
 
    
        看看效果,做一个分文件就这么简单,还完全实现了页面与逻辑分离
            | 以下为引用的内容: <?
 require("inc_datalist.php");
 $dlist = new DataList();
 $dlist->Init();
 $dlist->SetTemplet("./test.htm");
 $dlist->SetSource("select * from ttt");
 $liststring = $dlist->Display();
 $dlist->Close();
 ?>
 
 |  假如我要增加一个GET字符串传递给查询应该怎么做呢?
 Easy
 假如增加的查询串为 keyword
 
 
    
        还有什么不能解决吗?
            | 以下为引用的内容: php程序员之家 <?
 require("inc_datalist.php");
 if(!isset($keyword)) $keyword="";
 $dlist = new DataList();
 $dlist->Init();
 $dlist->SetParameter("keyword",$keyword);
 $dlist->SetTemplet("./test.htm");
 $dlist->SetSource("select * from ttt where bb like '%$keyword%'");
 $liststring = $dlist->Display();
 $dlist->Close();
 ?>
 
 |  假如有一个字段是布尔值,我想输出时按不同情况输出不同内容,其实不难实现
 Dede模板引擎支持使用自定义函数
 
 
    
        在程序里不用做什么,需要做的事情是更改一下模板
            | 以下为引用的内容: <?
 require("inc_datalist.php");
 phperz.com if(!isset($keyword)) $keyword="";
 function GetMyName($mname)
 {
 if($mname=="dede") return "My Name";
 else return $mname;
 }
 $dlist = new DataList();
 $dlist->Init();
 $dlist->SetParameter("keyword",$keyword);
 $dlist->SetTemplet("./test.htm");
 $dlist->SetSource("select * from ttt where bb like '%$keyword%'");
 $liststring = $dlist->Display();
 $dlist->Close();
 ?>
 
 |  [field:aa function="GetMyName('@me')"/]
 这样返回的值就是函数返回的值。 php程序员站
 这样几乎达到尽善尽美的境界,唯一的是分页列表的链接是固定的,不过你可以对它进行改进。  php程序员之家  
 |