快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

发布一个最强的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 分页类
    微笑服务 优质保证 索取样品