代碼:
$ppp = $keyword ? $keyword : 20; //一頁顯示數目
$page = empty($page) || !ispage($page) ? 1 : $page;
$start_limit = $numpost =($page - 1) * $ppp;
//分頁
$query = $db->query("SELECT COUNT(*) as total FROM {$tablepre}{$table}
WHERE $condition");//獲取該類別的記錄總數
$result = $db->fetch_array($query);
$multipage = setpage("list.php?action=$action&page={n}",$page,@ceil
($result['total'] / $ppp));
//end
$sql = "SELECT $dotadd FROM {$tablepre}{$table} t WHERE $condition
$groupby $orderby LIMIT $start_limit, $ppp";
調用函數:
//分頁
function pageItemList($cp,$url,$n,$sF,$sN,$tgt=''){
$target = $tgt ? ' target="'.$tgt.'"' : '';
$sF = ($sF<=0) ? 1 : $sF;
$sN = ($sN>$n) ? $n : $sN;
$page_pre = str_replace('{n}',($cp-1),$url);
$page_next = str_replace('{n}',($cp+1),$url);
if($cp<=1){
$rtv .= '<span>上一頁</span>';
} else {
$rtv .= '<a href="'.$page_pre.'"'.$target.'>上一頁</a>';
}
for($i=$sF;$i<=$sN;$i++){
if($cp==$i){
$rtv .= '<span class="s">'.$i.'</span>';
} else {
$lct=str_replace('{n}',$i,$url);
$rtv .= '<a href="'.$lct.'"'.$target.'>'.$i.'</a>';
}
}
if($cp>=$n){
$rtv .= '<span>下一頁</span>';
} else {
$rtv .= '<a href="'.$page_next.'"'.$target.'>下一頁</a>';
}
return $rtv;
}
function setpage($url,$cp,$n,$tgt=''){
if(intval($n)==0)return;
$target = $tgt ? ' target="'.$tgt.'"' : '';
$page_first = str_replace('{n}','1',$url);
$page_last = str_replace('{n}',$n,$url);
if($cp<=1){
$rtv .= '<span>第一頁</span>';
} else {
$rtv .= '<a href="'.$page_first.'"'.$target.'>第一頁</a>';
}
if($n>=10){
if($cp<=4){
$rtv .= $cp>1 ? pageItemList($cp,$url,$n,1,10,$tgt) :
pageItemList($cp,$url,$n,1,($cp+9),$tgt);
} else {
$rtv .= pageItemList($cp,$url,$n,($cp-4),($cp+5),$tgt);
}
} else {
$rtv .= pageItemList($cp,$url,$n,1,$n,$tgt);
}
if($cp>=$n){
$rtv .= '<span>最後一頁</span>';
}else{
$rtv .= '<a href="'.$page_last.'"'.$target.'>最後一頁</a>';
}
return $rtv;
}
樣式:
.morepage {float:right;line-height:23px;text-align:right;}
.morepage a,.morepage span {float:left;padding:0 5px;margin:0 4px;border:1px
solid #999;background-color:#f2f2f2;font-size:14px;font-family:Arial;}
.morepage a.s,.morepage span.s {background-color:#f60;font-
weight:bold;color:#fff;border:1px solid #f60;}
.morepage a {text-decoration:underline;}
調用:
<div class="morepage">
$multipage
</div>