如果你学过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 ); |
以下为引用的内容: {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> |
以下为引用的内容: <? require("inc_datalist.php"); $dlist = new DataList(); $dlist->Init(); $dlist->SetTemplet("./test.htm"); $dlist->SetSource("select * from ttt"); $liststring = $dlist->Display(); $dlist->Close(); ?> |
以下为引用的内容: <? 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(); ?> |
以下为引用的内容: <? require("inc_datalist.php"); 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(); ?> |
这样几乎达到尽善尽美的境界,唯一的是分页列表的链接是固定的,不过你可以对它进行改进。