效果图:
记得以前看到过一个页码方式的分页效果,页码数多了折行继续显示一直到60多页,呵呵!有点影响美观!
于是写了一个,可以自动适应范围的页码分页程序
也就是说,页码格式如下
4 5 6 7 > >>
9 10 11 12 > >>
下划线为当前页,这样就可以固定显示一个相近的页码,避免太长影响美观
代码加了注释,主要是新手看看,呵呵 ,写这个函数,没有考虑表现结构分离问题,高手就不要追究了!
复制内容到剪贴板
代码:$pages) $page = $pages;
//计算查询偏移量
$offset = $pagesize*($page-1);
//页码范围计算
$init = 1;//起始页码数
$max = $pages;//结束页码数
$pagelen = ($pagelen%2)?$pagelen:$pagelen+1;//页码个数
$pageoffset = ($pagelen-1)/2;//页码个数左右偏移量
//生成html
$pagecode='';
$pagecode.=$page/$pages;//第几页,共几页
//如果是第一页,则不显示第一页和上一页的连接
if($page!=1){
$pagecode.=;//第一页
$pagecode.=;//上一页
}
//分页数大于页码个数时可以偏移
if($pages>$pagelen){
//如果当前页小于等于左偏移
if($page $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 if($i==$page){
$pagecode.=''.$i.'';
} else {
$pagecode.=$i;
}
}
if($page!=$pages){
$pagecode.=>;//下一页
$pagecode.=>>;//最后一页
}
$pagecode.='
';
return array('pagecode'=>$pagecode,'sqllimit'=>' limit '.$offset.','.$pagesize);
}
?>函数参数:
$page 当前$_get获得的页码
$total 总记录数
$phpfile 页码连接文件名
$pagesize 不用解释了吧 呵呵
$pagelen 最多显示几个页码 注意(奇数),对称嘛!
函数返回一个数组:
pagecode 索引对应的内容是 生成的html 代码
sqllimit 索引对应的是sql limit 后缀
使用方法: 复制内容到剪贴板
代码:counts('select `id` from `test`');
$sql='select `id`,`title` from `test`';
$getpageinfo = page($page,$counts,$phpfile);
$sql.=$getpageinfo['sqllimit'];
$data = $db->getrows($sql);
?>
补贴css 复制内容到剪贴板
代码:
以下是html网页特效代码,点击运行按钮可查看效果:
以下是程序代码
123456789101112131415
欢迎访问阿里西西网页特效代码站,js.alixixi.com
[ctrl+a 全部选择 提示:你可先修改部分代码,再按运行]