/**
* 获取分页的HTML内容
* @param integer $page 当前页
* @param integer $pages 总页数
* @param string $url 跳转url地址 最后的页数以 '&page=x' 追加在url后面
*
* @return string HTML内容;
*/
public static function getPageHtml($page, $pages, $url){
//最多显示多少个页码
$_pageNum = 5;
//当前页面小于1 则为1
$page = $page<1?1:$page;
//当前页大于总页数 则为总页数
$page = $page > $pages ? $pages : $page;
//页数小当前页 则为当前页
$pages = $pages < $page ? $page : $pages;
//计算开始页
$_start = $page - floor($_pageNum/2);
$_start = $_start<1 ? 1 : $_start;
//计算结束页
$_end = $page + floor($_pageNum/2);
$_end = $_end>$pages? $pages : $_end;
//当前显示的页码个数不够最大页码数,在进行左右调整
$_curPageNum = $_end-$_start+1;
//左调整
if($_curPageNum<$_pageNum && $_start>1){
$_start = $_start - ($_pageNum-$_curPageNum);
$_start = $_start<1 ? 1 : $_start;
$_curPageNum = $_end-$_start+1;
}
//右边调整
if($_curPageNum<$_pageNum && $_end<$pages){
$_end = $_end + ($_pageNum-$_curPageNum);
$_end = $_end>$pages? $pages : $_end;
}
$_pageHtml = '
$index_start = $page *30 +1;
$index_end = ($page+1)*30;
for ($j, $j <= $index_end, ++$j){
echo 以$j为编号的东西
}
没有具体试过,但是大概就是这个概念了吧。 $page就是页数,$index_start是第一项的编号
$index_end是最后一项的编号。
function get_pagelist($page, $total, $file, $per, $pagelen)
{
$pages=ceil($total/$per);//总页数
$init=1;//起始页
$max=$pages;//结束页
$offset=($page-1)*$per;//偏移量
$pageoffset=($pagelen-1)/2;
if($page!=1){
$code.="第一页";
$code.="上一页";
}else{
$code.="第一页";
$code.="上一页";
}
if($pages > $pagelen){
if($page <= $pageoffset){
$init=1;
$max=$pagelen;
}else{
if($page+$pageoffset >=$pages+1){
$init=$pages-$pageoffset+1;
}else{
$init=$page-$pageoffset;
$max=$page+$pageoffset;
}
}
}
for($i=$init;$i<= $max;$i++){
if($i == $page){
$code.="".$i."";
}else{
$code.=" ".$i." ";
}
}
if($page!=$pages){
$code.="下一页";
$code.="末页";
}else{
$code.="下一页";
$code.="末页";
}
return array('code' => $code, 'limit' => ' limit ' . $offset . ',' . $per);
}
去网上下载一个分页类吧 然后引用到代码里面