一個PHP分頁函數
PHP分頁代碼調用: $start=show_page($query,$page,$link,$offset);其中: $start為起始記錄 $query為全記錄檢索SQL語句 $page為當前頁碼 $link為傳遞的頁面參數 $offset為每頁顯示記錄數
<?php
//======function.php=====
//======分頁函數==========
function show_page($query,$page,$link,$offset)
{
$db = new mysql();
$result = $db->query($query);
$Page_size = $offset; //取得每頁顯示的最大訂單數
$count = $db->affected_rows($result); //總訂單數
$page_count = ceil($count/$Page_size); //計算得出總頁數
$init=1;
$page_len=7;
$max_p=$page_count;
$pages=$page_count;
//判斷當前頁碼
$page=(empty($page)||$page<0)?1:$page;
$start=$Page_size*($page-1);
//分頁功能代碼
$page_len = ($page_len%2)?$page_len:$pagelen+1; //頁碼個數
$pageoffset = ($page_len-1)/2; //頁碼個數左右偏移量
$key="共 $count 條 ";
$key.="$page/$pages "; //第幾頁,共幾頁
if($page!=1){
$key.="<a href=\"".$_SERVER['PHP_SELF']."?page=1&$link\">第一頁</a> "; //第一頁
$key.="<a href=\"".$_SERVER['PHP_SELF']."?page=".($page-1)."&$link\">上一頁</a>"; //上一頁
}
else
{
$key.="第一頁 ";//第一頁
$key.="上一頁"; //上一頁
}
if($pages>$page_len)
{
//如果當前頁小于等于左偏移
if($page<=$pageoffset){
$init=1;
$max_p = $page_len;
}
else //如果當前頁大于左偏移
{
//如果當前頁碼右偏移超出最大分頁數
if($page+$pageoffset>=$pages+1){
$init = $pages-$page_len+1;
}
else
{
//左右偏移都存在時的計算
$init = $page-$pageoffset;
$max_p = $page+$pageoffset;
}
}
}
for($i=$init;$i<=$max_p;$i++)
{
if($i==$page){$key.=' ['.$i.']';}
else {$key.=" <a href=\"".$_SERVER['PHP_SELF']."?page=".$i."&$link\">".$i."</a>";}
}
if($page!=$pages)
{
$key.=" <a href=\"".$_SERVER['PHP_SELF']."?page=".($page+1)."&$link\">下一頁</a> ";//下一頁
$key.="<a href=\"".$_SERVER['PHP_SELF']."?page=".$pages."&$link\">最后一頁</a>"; //最后一頁
}
else
{
$key.="下一頁 "; //下一頁
$key.="最后一頁"; //最后一頁
}
echo "$key<BR><BR>";
return $start;
}
?></pre>
調用示例
<?php
include("../include/mysql.class.php");
include("../include/function.php");
$query = "select * from $table order by id desc";
$offset=($_GET[offset]!='')?$_GET[offset]:$offset;
$start=show_page($query,$_GET[page],"offset=$offset",$offset);
$db->close();
?> </pre>