|
发布一个最强的PHP通用分页类
假如你学过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 {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> 3、编写调用这个类的代码 数据库的连接信息均在config_base.php这个文件是设定 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 <? 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"); 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与SQL注入攻击[二] 下一教程: Windows XP下集成Tomcat与Apache
您可以阅读与"发布一个最强的PHP通用分页类"相关的教程: · 测试已经无误,重新发布的修改后的分页类,附点说明 · PHP实现分页的一个示例 · 一个在PHP中利用递归实现论坛分级显示的例子(为了简朴起见,我将分页显示部分去掉了) · 发布一个图形数字验证代码 · php+oracle 分页类
|