PHP自动适应范围的页码分页程序

效果图:
 
记得以前看到过一个页码方式的分页效果,页码数多了折行继续显示一直到60多页,呵呵!有点影响美观!

于是写了一个,可以自动适应范围的页码分页程序
也就是说,页码格式如下
<< < 1 2 3 4 5 6 7 > >>
<< < 6 7 8 9 10 11 12 > >>

下划线为当前页,这样就可以固定显示一个相近的页码,避免太长影响美观
代码加了注释,主要是新手看看,呵呵 ,写这个函数,没有考虑表现结构分离问题,高手就不要追究了!

<?php
function page($page,$total,$phpfile,$pagesize=10,$pagelen=7){
$pagecode = ”;//定义变量,存放分页生成的HTML
$page = intval($page);//避免非数字页码
$total = intval($total);//保证总记录数值类型正确
if(!$total) return array();//总记录数为零返回空数组
$pages = ceil($total/$pagesize);//计算总分页
//处理页码合法性
if($page<1) $page = 1;
if($page>$pages) $page = $pages;
//计算查询偏移量
$offset = $pagesize*($page-1);
//页码范围计算
$init = 1;//起始页码数
$max = $pages;//结束页码数
$pagelen = ($pagelen%2)?$pagelen:$pagelen+1;//页码个数
$pageoffset = ($pagelen-1)/2;//页码个数左右偏移量

//生成html
$pagecode='<div class="page">’;
$pagecode.="<span>$page/$pages</span>";//第几页,共几页
//如果是第一页,则不显示第一页和上一页的连接
if($page!=1){
$pagecode.="<a href="{$phpfile}?page=1">&lt;&lt;</a>";//第一页
$pagecode.="<a href="{$phpfile}?page=".($page-1)."">&lt;</a>";//上一页
}
//分页数大于页码个数时可以偏移
if($pages>$pagelen){
//如果当前页小于等于左偏移
if($page<=$pageoffset){
$init=1;
$max = $pagelen;
}else{//如果当前页大于左偏移
//如果当前页码右偏移超出最大分页数
if($page+$pageoffset>=$pages+1){
$init = $pages-$pagelen+1;
}else{
//左右偏移都存在时的计算
$init = $page-$pageoffset;
$max = $page+$pageoffset;
}
}
}
//生成html
for($i=$init;$i<=$max;$i++){
if($i==$page){
$pagecode.='<span>’.$i.'</span>’;
} else {
$pagecode.="<a href="{$phpfile}?page={$i}">$i</a>";
}
}
if($page!=$pages){
$pagecode.="<a href="{$phpfile}?page=".($page+1)."">&gt;</a>";//下一页
$pagecode.="<a href="{$phpfile}?page={$pages}">&gt;&gt;</a>";//最后一页
}
$pagecode.='</div>’;
return array(‘pagecode’=>$pagecode,’sqllimit’=>’ limit ‘.$offset.’,’.$pagesize);
}
?>

函数参数:

$page 当前$_GET获得的页码
$total 总记录数
$phpfile 页码连接文件名
$pagesize 不用解释了吧 呵呵
$pagelen 最多显示几个页码 注意(奇数),对称嘛!
函数返回一个数组:
pagecode 索引对应的内容是 生成的HTML 代码
sqllimit 索引对应的是sql limit 后缀

使用方法:

<?php
$phpfile = ‘index.php’;
$page= isset($_GET[‘page’])?$_GET[‘page’]:1;
$db = new Mysql();
$counts = $db->counts(‘select `id` from `test`’);
$sql=’select `id`,`title` from `test`’;
$getpageinfo = page($page,$counts,$phpfile);
$sql.=$getpageinfo[‘sqllimit’];
$data = $db->getRows($sql);
?>
<?php
echo $getpageinfo[‘pagecode’];//显示分页的html代码
?>

css

<style type="text/css">
body{font-family:Tahoma;}
.page{padding:2px;font-weight:bolder;font-size:12px;}
.page a{border:1px solid #ccc;padding:0 5px 0 5px;margin:2px;text-decoration:none;color:#333;}
.page span{padding:0 5px 0 5px;margin:2px;background:#09f;color:#fff;border:1px solid #09c;}
</style>

波比源码 – 精品源码模版分享 | www.bobi11.com
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 本站源码并不保证全部能正常使用,仅供有技术基础的人学习研究,请谨慎下载
8. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!

波比源码 » PHP自动适应范围的页码分页程序

67 评论

  1. cheap ampicillin 500mg bactrim 960mg uk order erythromycin 500mg

  2. sildenafil 50mg without prescription sildenafil order methocarbamol brand

  3. terazosin without prescription leflunomide uk buy generic azulfidine 500mg

  4. benicar brand order diamox buy generic diamox

  5. order dapsone sale adalat 10mg ca order aceon 4mg online

  6. order nootropil 800 mg without prescription pfizer viagra brand sildenafil 100mg

  7. buy cialis 40mg sale price of cialis buy anafranil 50mg sale

  8. order chloroquine 250mg online cheap olumiant drug olumiant pills

  9. purchase amlodipine online cheap amlodipine order cialis 20mg pill

  10. order viagra 50mg pills viagra 100mg uk order lisinopril 5mg generic

  11. tadalafil 40mg tablet cialis canada viagra 50mg pills for men

  12. order xenical 120mg online cheap acyclovir price oral acyclovir 400mg

  13. order methotrexate 2.5mg warfarin 2mg drug purchase metoclopramide pills

  14. order colchicine online casino games online win real money online casino for free

  15. buy zocor 10mg for sale oral zocor buy proscar

  16. cephalexin 500mg without prescription order cleocin pill order erythromycin 250mg without prescription

  17. playing poker online for money ocean casino online purchase tadalafil online cheap

发表评论

Hi, 如果你对这款模板有疑问,可以跟我联系哦!

联系站长
赞助VIP 享更多特权,建议使用 QQ 登录
喜欢我嘛?喜欢就按“ctrl+D”收藏我吧!♡