溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP中怎么實(shí)現(xiàn)一個(gè)分頁(yè)函數(shù)

發(fā)布時(shí)間:2021-07-28 14:02:27 來源:億速云 閱讀:131 作者:Leah 欄目:編程語言

PHP中怎么實(shí)現(xiàn)一個(gè)分頁(yè)函數(shù),針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。

寫列表性質(zhì)的頁(yè)面,幾乎都要寫上一段分頁(yè)的程序。最近小陽(yáng)終于決心一勞永逸——自定義一個(gè)分頁(yè)函數(shù),并保存在“pageft.php”文件里。要用 到分頁(yè)的地方,就直接包含“pageft.php”文件,并調(diào)用這個(gè)函數(shù)就行了。小陽(yáng)在編寫這個(gè)函數(shù)時(shí),盡量注意了程序的可移植性和易用性,下面就是小陽(yáng)編寫的PHP分頁(yè)函數(shù):

  1. < ?  

  2. //為了避免重復(fù)包含文件而造成錯(cuò)誤,
    加了判斷函數(shù)是否存在的條件:  

  3. if(!function_exists(pageft)){  

  4. //定義函數(shù)pageft(),三個(gè)參數(shù)的含義為:  

  5. //$totle:信息總數(shù);  

  6. //$displaypg:每頁(yè)顯示信息數(shù),這里設(shè)置為默認(rèn)是20;  

  7. //$url:分頁(yè)導(dǎo)航中的鏈接,除了加入不同的查詢信息
    “page”外的部分都與這個(gè)URL相同。  

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

  9. function pageft($totle,$displaypg=20,$url=”){  

  10. //定義幾個(gè)全局變量:  

  11. //$page:當(dāng)前頁(yè)碼;  

  12. //$firstcount:(數(shù)據(jù)庫(kù))查詢的起始項(xiàng);  

  13. //$pagenav:頁(yè)面導(dǎo)航條代碼,函數(shù)內(nèi)部并沒有將它輸出;  

  14. //$_SERVER:讀取本頁(yè)URL“$_SERVER["REQUEST_URI"]”所必須。  

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

  16. //為使函數(shù)外部可以訪問這里的“$displaypg”,
    將它也設(shè)為全局變量。注意一個(gè)變量重新定
    義為全局變量后,原值被覆蓋,所以這里給它重新賦值。  

  17. $GLOBALS["displaypg"]=$displaypg;  

  18. if(!$page) $page=1;  

  19. //如果$url使用默認(rèn),即空值,則賦值為本頁(yè)URL:  

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

  21. //URL分析:  

  22. $parse_urlparse_url=parse_url($url);  

  23. $url_query=$parse_url["query"]; 
    //單獨(dú)取出URL的查詢字串  

  24. if($url_query){  

  25. //因?yàn)閁RL中可能包含了頁(yè)碼信息,我們要把它去掉,
    以便加入新的頁(yè)碼信息。  

  26. //這里用到了正則表達(dá)式,請(qǐng)參考“PHP中的正規(guī)表達(dá)式”
    (http://www.pconline.com.cn
    /pcedu/empolder/wz/php/10111/15058.html)  

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

  28.  

  29. //將處理后的URL的查詢字串替換原來的URL的查詢字串:  

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

  31.  

  32. //在URL后加page查詢信息,但待賦值:  

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

  34. }else {  

  35. $url.=”?page”;  

  36. }  

PHP分頁(yè)函數(shù)的頁(yè)碼計(jì)算:

  1. $lastpg=ceil($totle/$displaypg);   

  2. //***頁(yè),也是總頁(yè)數(shù)  

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

  4. $prepg=$page-1;   

  5. //上一頁(yè)  

  6. $nextpg=($page==$lastpg ? 0 : $page+1);   

  7. //下一頁(yè)  

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

  9. //開始分頁(yè)導(dǎo)航條代碼:  

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

  11. //如果只有一頁(yè)則跳出函數(shù):  

  12. if($lastpg<=1) return false;  

  13. $pagenav.=” < a href=&rsquo;$url=1&prime;>首頁(yè)< /a> “;  

  14. if($prepg) $pagenav.=” < a href=&rsquo;$url=$prepg&rsquo;>
    前頁(yè)< /a> “; else $pagenav.=” 前頁(yè) “;  

  15. if($nextpg) $pagenav.=” < a href=&rsquo;$url=$nextpg&rsquo;>
    后頁(yè)< /a> “; else $pagenav.=” 后頁(yè) “;  

  16. $pagenav.=” < a href=&rsquo;$url=$lastpg&rsquo;>尾頁(yè)< /a> “;  

  17. //下拉跳轉(zhuǎn)列表,循環(huán)列出所有頁(yè)碼:  

  18. $pagenav.=” 到第 < select name=&rsquo;topage&rsquo; 
    size=&rsquo;1&prime; onchange=&rsquo;window.location=\”
    $url=\”+this.value&rsquo;>\n”;  

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

  20. if($i==$page) $pagenav.=”< option value=&rsquo;$i&rsquo;
     selected>$i< /option>\n”;  

  21. else $pagenav.=”< option value=&rsquo;$i&rsquo;>$i< /option>\n”;  

  22. }  

  23. $pagenav.=”< /select> 頁(yè),共 $lastpg 頁(yè)”;  

  24. }  

  25. }  

  26. ?> 

好,PHP分頁(yè)函數(shù)已經(jīng)寫好了,保存為“pageft.php”,要分頁(yè)時(shí)就包含它并調(diào)用pageft()函數(shù)。不過它并沒有輸出任何東西,但產(chǎn)生幾個(gè)全局變量供使用:$firstcount、$displaypg、$pagenav。

下面舉例說明PHP分頁(yè)函數(shù)的用法:

  1. < ?  

  2. //(前面程序略)  

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

  4. //取得總信息數(shù)  

  5. $result=mysql_query(”select 
    * from mytable”);  

  6. $total=mysql_num_rows($result);  

  7. //調(diào)用pageft(),每頁(yè)顯示10條信息
    (使用默認(rèn)的20時(shí),可以省略此參數(shù)),
    使用本頁(yè)URL(默認(rèn),所以省略掉)。  

  8. pageft($total,10);  

  9. //現(xiàn)在產(chǎn)生的全局變量就派上用場(chǎng)了:  

  10. $result=mysql_query(”select * 
    from mytable limit $firstcount,
    $displaypg “);  

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

  12. //(列表內(nèi)容略)  

  13. }  

  14. //輸出分頁(yè)導(dǎo)航條代碼:  

  15. echo $pagenav;  

  16. //(后面程序略)  

  17. ?> 

關(guān)于PHP中怎么實(shí)現(xiàn)一個(gè)分頁(yè)函數(shù)問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI