• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

发布一个最强的PHP通用分页类_php

php 搞代码 7年前 (2018-06-21) 119次浏览 已收录 0个评论

如果你学过asp.net,你一定知道它里面有一个叫datalist之类自带的分页功能十分强大,这里的这个类就模拟了一部份这个功能,我敢用“强大”来定义它,是因为作为一个通用的页类,这个类真正做到了“通用”。
废话少说,马上介绍一下是如何使用的。
1、先新建一个用于测试的表
CREATE TABLE `test` (
`aa` INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
`bb` VARCHAR(50) NOT NULL,

http://www.gaodaima.com/48144.html发布一个最强的php通用分页类_php

`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通用分页类_php》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:发布一个最强的PHP通用分页类_php
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址