All articles(网络文学目录) All Pictures(图片目录) All Softwares(软件目录)

 
发布一个最强的PHP通用分页类_[PHP教程]

Writer: 归海一刀 Article type: Programming skills(编程技巧) Time: 2014/2/10 6:52:16 Browse times: 416 Comment times: 0

发布一个最强的PHP通用分页类_[PHP教程]


Head photo

Go homepage
Upload pictures
Write articles

发布一个最强的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.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')"/]
这样返回的值就是函数返回的值。

这样几乎达到尽善尽美的境界,唯一的是分页列表的链接是固定的,不过你可以对它进行改进。





There are 0 records,
Comment:
Must be registered users to comment(必须是注册用户才能发表评论)

Disclaimer Privacy Policy About us Site Map
Copyright ©2011-
uuhomepage.com, Inc. All rights reserved.