當前位置:編程學習大全網 - 源碼下載 - 自定義PHP分頁函數

自定義PHP分頁函數

以下為引用的內容:

<?

//為了避免重復包含文件而造成錯誤,加了判斷函數是否存在的條件:

if(!function_exists(pageft)){

//定義函數pageft(),三個參數的含義為:

//$totle:信息總數;

//$displaypg:每頁顯示信息數,這裏設置為默認是20;

//$url:分頁導航中的鏈接,除了加入不同的查詢信息“page”外的部分都與這個URL相同。

//   默認值本該設為本頁URL(即$_SERVER["REQUEST_URI"]),但設置默認值的右邊只能為常量,所以該默認值設為空字符串,在函數內部再設置為本頁URL。

function pageft($totle,$displaypg=20,$url=''){

//定義幾個全局變量:

//$page:當前頁碼;

//$firstcount:(數據庫)查詢的起始項;

//$pagenav:頁面導航條代碼,函數內部並沒有將它輸出;

//$_SERVER:讀取本頁URL“$_SERVER["REQUEST_URI"]”所必須。

global $page,$firstcount,$pagenav,$_SERVER;

//為使函數外部可以訪問這裏的“$displaypg”,將它也設為全局變量。註意壹個變量重新定義為全局變量後,原值被覆蓋,所以這裏給它重新賦值。

$GLOBALS["displaypg"]=$displaypg;

$page=$_GET['page'];

if(!$page) $page=1;

//如果$url使用默認,即空值,則賦值為本頁URL:

if(!$url){ $url=$_SERVER["REQUEST_URI"];}

//URL分析:

$parse_url=parse_url($url);

$url_query=$parse_url["query"]; //單獨取出URL的查詢字串

if($url_query){

//因為URL中可能包含了頁碼信息,我們要把它去掉,以便加入新的頁碼信息。

//這裏用到了正則表達式,請參考“PHP中的正規表達式”(/pcedu/empolder/wz/php/10111/15058.html)

$url_query=ereg_replace("(^|&)page=$page","",$url_query);

//將處理後的URL的查詢字串替換原來的URL的查詢字串:

$url=str_replace($parse_url["query"],$url_query,$url);

//在URL後加page查詢信息,但待賦值:

if($url_query) $url.="&page"; else $url.="page";

}else {

$url.="?page";

}

//頁碼計算:

$lastpg=ceil($totle/$displaypg); //最後頁,也是總頁數

$page=min($lastpg,$page);

$prepg=$page-1; //上壹頁

$nextpg=($page==$lastpg ? 0 : $page+1); //下壹頁

$firstcount=($page-1)*$displaypg;

//開始分頁導航條代碼:

$pagenav="顯示第 <B>".($totle?($firstcount+1):0)."</B>-<B>".min($firstcount+$displaypg,$totle)."</B> 條記錄,*** $totle 條記錄";

//如果只有壹頁則跳出函數:

if($lastpg<=1) return false;

$pagenav.=" <a href='$url=1'>首頁</a> ";

if($prepg) $pagenav.=" <a href='$url=$prepg'>前頁</a> "; else $pagenav.=" 前頁 ";

if($nextpg) $pagenav.=" <a href='$url=$nextpg'>後頁</a> "; else $pagenav.=" 後頁 ";

$pagenav.=" <a href='$url=$lastpg'>尾頁</a> ";

//下拉跳轉列表,循環列出所有頁碼:

$pagenav.=" 到第 <select name='topage' size='1' onchange='window.location=\"$url=\"+this.value'>\n";

for($i=1;$i<=$lastpg;$i++){

if($i==$page) $pagenav.="<option value='$i' selected>$i</option>\n";

else $pagenav.="<option value='$i'>$i</option>\n";

}

$pagenav.="</select> 頁,*** $lastpg 頁";

}

}

>

php=mysql調用方法:

<?

//(前面程序略)

include("pageft.php"); //包含“pageft.php”文件

//取得總信息數

$result=mysql_query("select * from mytable");

$total=mysql_num_rows($result);

//調用pageft(),每頁顯示10條信息(使用默認的20時,可以省略此參數),使用本頁URL(默認,所以省略掉)。

pageft($total,10);

//現在產生的全局變量就派上用場了:

$result=mysql_query("select * from mytable limit $firstcount,$displaypg ");

while($row=mysql_fetch_array($result)){

//(列表內容略)

}

>

//-----------用法

連接sqlserver

<?php

$query="select * from zhufu";

$result=mssqlresult($query);

$numrows = mssql_num_rows($result);

$pagesize=20;

$Url="index.php";

pageft($numrows,$pagesize,$Url);

$sql = "select top $pagesize * from zhufu where (id not in (select top $firstcount id from zhufu order by id desc)) order by id desc";

//echo $sql;

$result1= mssqlresult($sql);

while( $row=mssql_fetch_assoc($result1))

{

$row1=trim($row["city"]).trim($row["xuexiao"]);

echo

"<tr>

<td class='bline fontblack' align = 'center'>".$row["id"]."</td>

<td class='bline' align='left'><span class='fontgreen'><font color='green'>".trim(iconv("gb2312","utf-8",$row["sendname"]))."</font> </span>給".trim(iconv("gb2312","utf-8",$row1))."的<font color='blue'>".trim(iconv("gb2312","utf-8",$row["name"]))."</font> 的祝福:<a href='info.php?id=".$row["id"]."' target='_blank'><font color='#E60638'>".trim((cut_str(iconv("gb2312","utf-8",$row["neirong"]),20)))."....</font></a></td>

<td class='bline' align = 'center'>".$row["riqi"]."</td>

</tr>

";

}

>

  • 上一篇:企業如何建立新零售數據指標體系?
  • 下一篇:誰能列個霹靂英雄的所有系列名稱目錄
  • copyright 2024編程學習大全網