初学者一般都不太理解分页的原理,因此常常为分页发愁
paging.php 首页 上一页 下一页 尾页'; $count = ceil(self::$count / self::$size); $page = self::$page; unset($_GET['page']); $d = array( 'reset' => 1, 'prve' => $page > 1 ? $page - 1 : 1, 'next' => $page < $count ? $page + 1 : $count, 'end' => $count, ); foreach($d as $k=>$v) { $_GET['page'] = $v; $tpl = str_replace($k, http_build_query($_GET), $tpl); } echo $tpl; } }
通常你都有类似这样的语句
$sql =".....";
$rs = mysql_query($sql);
或
$rs = mysql_query("select ....");
你只需改作
include 'paging.php';
$rs = paging::prepare($sql, 每页行数);
在需要出现分页条的地方写入
paging::bar();
就可以了,非常简单!
换一种调用写法,可能感觉要好些
paging.php
class Paging {
private static $_Instance;
private function __clone(){}
public static function getInstance() {
if(empty(self::$_Instance)) self::$_Instance = new self();
return self::$_Instance;
}
protected $count = 0;
protected $size = 0;
protected $page = 0;
function prepare($sql, $pagesize=10) {
$page = isset($_GET['page']) ? $_GET['page'] : 1;
$pageon = ($page - 1) * $pagesize;
$sql = preg_replace('/select\s/i', '$0SQL_CALC_FOUND_ROWS ', $sql) . " limit $pageon, $pagesize";
$rs = mysql_query($sql);
$p = mysql_query('SELECT FOUND_ROWS()');
list($this->count) = mysql_fetch_row($p);
$this->size = $pagesize;
$this->page = $page;
return $rs;
}
function bar($tpl='') {
if(!$tpl) $tpl = '共{count}页 第{page}页 首页 上一页 下一页 尾页';
$count = ceil($this->count / $this->size);
$page = $this->page;
$d = array(
'{reset}' => 1,
'{prve}' => $page > 1 ? $page - 1 : 1,
'{next}' => $page < $count ? $page + 1 : $count,
'{end}' => $count,
'{count}' => $count,
'{page}' => $page,
);
foreach($d as $k=>&$v) {
if(in_array($k, array('{reset}', '{prve}', '{next}', '{end}'))) {
$_GET['page'] = $v;
$v = http_build_query($_GET);
}
}
echo strtr($tpl, $d);
}
}
function mysql_paging_query($sql, $num=10) {
return Paging::getInstance()->prepare($sql, $num);
}
function mysql_paging_bar($tpl='') {
return Paging::getInstance()->bar($tpl);
}include 'paging.php'; $rs = mysql_paging_query($sql, 20);//替代 mysql_query mysql_paging_bar();//显示分页条
本文讲解了简易 php+mysql 分页类 相关知识请关注php中文网。
相关推荐:
一款非常包包、衣服、鞋子类网站,页面干净清洁、一目了然,mttshop打造精致、简单、易用、免费的商城。 系统要求:IIS5.1以后,必须安装.net 3.5 安装步骤: 1、下载完成后,直接解压文件mttshop.rar 2、附加数据库:解压后的可以找一个叫db的文件夹,解压后直接附加就可以,支持SQL 2000、2005、2008 3、配置web.config文件,找到key=&qu
立即学习“PHP免费学习笔记(深入)”;










