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