Go homepage(回首页) Upload pictures (上传图片) Write articles (发文字帖)
The author:(作者)归海一刀published in(发表于) 2014/2/10 6:52:16 发布一个最强的PHP通用分页类_[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/} aa bb cc tt{dede:datalist} [field:aa/] [field:bb/] [field:cc/] [field:tt function='date("Y-m-d H-i-s","@me")'/]{/dede} {dede:pagelist listsize=3/} 3、编写调用这个类的代码数据库的连接信息均在config_base.php这个文件是设定showtable.phprequire("inc_datalist.php");dlist = new DataList();dlist->Init();dlist->SetTemplet("./test.htm");dlist->SetSource("select * from ttt");liststring = dlist->Display();dlist->Close();?>看看效果,做一个分文件就这么简单,还完全实现了页面与逻辑分离假如我要增加一个GET字符串传递给查询应该怎么做呢?Easy假如增加的查询串为 keywordrequire("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')"/]这样返回的值就是函数返回的值。
这样几乎达到尽善尽美的境界,唯一的是分页列表的链接是固定的,不过你可以对它进行改进。
赞