首頁 後端開發 php教程 PHP分頁顯示製作詳細解說_PHP教程

PHP分頁顯示製作詳細解說_PHP教程

Jul 21, 2016 pm 04:08 PM
php 分頁 製作 前言 屬於 數據 方法 顯示 瀏覽 講解 詳細

1、前言

分页显示是一种非常常见的浏览和显示大量数据的方法,属于web编程中最常处理的事件之一。对于web编程的老手来说,编写这种代码实在是和呼吸一样自然,但是对于初学者来说,常常对这个问题摸不着头绪,因此特地撰写此文对这个问题进行详细的讲解,力求让看完这篇文章的朋友在看完以后对于分页显示的原理和实现方法有所了解。本文适合初学者阅读,所有示例代码均使用php编写。

2、原理

所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数:

每页多少条记录($PageSize)?
当前是第几页($CurrentPageID)?

现在只要再给我一个结果集,我就可以显示某段特定的结果出来。
至于其他的参数,比如:上一页($PreviousPageID)、下一页($NextPageID)、总页数($numPages)等等,都可以根据前边这几个东西得到。
以mysql数据库为例,如果要从表内截取某段内容,sql语句可以用:select * from table limit offset, rows。看看下面一组sql语句,尝试一下发现其中的规率。

前10条记录:select * from table limit 0,10
第11至20条记录:select * from table limit 10,10
第21至30条记录:select * from table limit 20,10
……

这一组sql语句其实就是当$PageSize=10的时候取表内每一页数据的sql语句,我们可以总结出这样一个模板:

select * from table limit ($CurrentPageID - 1) * $PageSize, $PageSize

拿这个模板代入对应的值和上边那一组sql语句对照一下看看是不是那么回事。搞定了最重要的如何获取数据的问题以后,剩下的就仅仅是传递参数,构造合适的sql语句然后使用php从数据库内获取数据并显示了。以下我将用具体代码加以说明。

3、简单代码
请详细阅读以下代码,自己调试运行一次,最好把它修改一次,加上自己的功能,比如搜索等等。

// 建立数据库连接
$link = mysql_connect("localhost", "mysql_user", "mysql_password")
or die("Could not connect: " . mysql_error());
// 获取当前页数
if( isset($_GET['page']) ){
$page = intval( $_GET['page'] );
}
else{
$page = 1;
}
// 每页数量
$PageSize = 10;
// 获取总数据量
$sql = "select count(*) as amount from table";
$result = mysql_query($sql);
$row = mysql_fetch_row($result);
$amount = $row['amount'];
// 记算总共有多少页
if( $amount ){
if( $amount < $page_size ){ $page_count = 1; } //如果总数据量小于$PageSize,那么只有一页
if( $amount % $page_size ){ //取总数据量除以每页数的余数
$page_count = (int)($amount / $page_size) + 1; //如果有余数,则页数等于总数据量除以每页数的结果取整再加一
}else{
$page_count = $amount / $page_size; //如果没有余数,则页数等于总数据量除以每页数的结果
}
}
else{
$page_count = 0;
}

// 翻页链接
$page_string = '';
if( $page == 1 ){
$page_string .= '第一页|上一页|';
}
else{
$page_string .= '第一页|上一页|';
}
if( ($page == $page_count) || ($page_count == 0) ){
   $page_string .= '下一页|尾页';
}
else{
   $page_string .= '下一页|尾页';
}
// 获取数据,以二维数组格式返回结果
if( $amount ){
   $sql = "select * from table order by id desc limit ". ($page-1)*$page_size .", $page_size";
   $result = mysql_query($sql);

   while ( $row = mysql_fetch_row($result) ){
       $rowset[] = $row;
   }
}else{
   $rowset = array();
}
// 没有包含显示结果的代码,那不在讨论范围,只要用foreach就可以很简单的用得到的二维数组来显示结果
?>

4、OO风格代码
以下代码中的数据库连接是使用的pear db类进行处理

// FileName: Pager.class.php
// 分頁類,這個類別僅用於處理資料結構,不負責處理顯示的工作
Class Pager
{
   var $PageSize;             //每頁的數量
   var $CurrentPageID      //下一頁
   var $PreviousPageID;       //上一頁
   var $numPages;             //總頁數
   var $numItems;          //是否第一頁
   var $isLastPage;           //是否為最後一頁
   var $sql;                  //sql查詢語句

      $this->_setOptions($option);
       // 總條數
       if ( !isset($this->numItems) )
                 $this- >numItems = $res->numRows();
       }
       // 總頁數
             if ( $this->numItems PageSize ){ $this->numPages = 1; }
           if ( $this->numItems % $this->PageSize )numPages= (int) ($this->numItems / $this->PageSize) 1;
           }
                   $this->numPages = $this->numItems / $this->PageSize;
           }
       }
        else
    >       }

       switch ( $this->CurrentPageID )
       {
case $this->numPages == 1:
               $this->isFirstPage = true;
               break;
           case 1:
           isFirstPage = true;
               $this->isLastPage = false;
     ase $this->numPages:
               $this->isFirstPage = false;
     true;
               break;
           🎜>               $this->isLastPage = false;
       }

       if ( $this->numPages > 1 )
       {
      }
if ( !$this->isFirstPage ) { $this->PreviousPageID = $this->CurrentPageID - 1; }
       }
        }
 **
    *
    * 回傳結果集的資料庫連接
    * 在結果集比較大的時候可以直接使用此方法取得資料庫連接,然後在類別之外遍歷,這樣開銷   如果結果集不是很大,可以直接使用getPageData的方式取得二維陣列格式的結果
    * getPageData方法是使用二維陣列格式的結果
    *
    ***/

   function getDataLink()
   {
       if ( $this->num db;

           $PageID = $this->CurrentPageID;

           $from = ($PageID - 1) *$this->PageSize;limitQuery($this->sql, $from, $count);   //使用梨子db :: limitquery方法保證資料庫相容性

回傳$ link;
}
else
回傳$ link;
}
else
{
{
回傳false;
}
} } }

   /***
    *
    * 以二維陣列的格式傳回結果集
    *
    ***/

   /***/

   /***/

  🎜>   {
       if ( $this->numItems )
       {
        {      
               if ( $res->numRows() )
               {
                   while ( $row = $res->fetchRow() )
                   {
                       $result[] = $row;
                  }
               }
               else
               {
                  🎜>回傳$結果;
           }
           else           }
       }
       else
       {
        

   function _setOptions($option)
   {
       $allow_options = array(                   'CurrentPageID',
                 'numItems '
       );

       foreach ( $option as $key => $value )
   tions) && ($value != null) )
           {
               $this->$key = $value  >
       return true;
   }
}
?>
// FileName: test_pager.php
// 這是一段簡單的範例程式碼,前邊省略了使用pear db類別建立資料庫連線的程式碼
require "Pager.class.php";
if ( isset($_GET['page']) )
{
   $page = (int)$_GET['page'];
}
else
{
   $page = 1;
}
$sql = "select * from table order by id";
$pager_option = array(
   PageSize" => 10,
       "CurrentPageID" => $page
);
if ( isset($_GET['numItems']) )
{
{}
$pager = @new Pager($pager_option);
$data = $pager->getPageData();
if ( $pager->isFirstPage )
{
   $turnover = "首頁|上一頁|";
}
else
{
   $turnover = "首頁|上一頁|";
}
if ( $pager->isLastPage )
{
   $turnover .= "下一頁|尾頁";
}
else
{
   $turnover .= "下一頁|尾頁";
}
? >
 

需要說明的地方有兩個:

這個類僅僅處理數據,並不負責處理顯示,因為我覺得將數據的處理和結果的顯示都放到一個類裡邊實在是有些勉強。顯示的時候情況和要求多變,不如自己根據類別給出的結果處理,更好的方法是根據這個Pager類別繼承一個自己的子類別來顯示不同的分頁,例如顯示使用者分頁列表可以:

Class MemberPager extends Pager
{

   function showMemberList()

   {

   ( );

// 顯示結果的程式碼

       // ......

   }
}
/// 呼叫
if ( isset($_GET[🎜>/// 呼叫
if ( isset($_GET['page' ]) )
{
   $page = (int)$_GET['page'];
}
else
{
   $page = 1;
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
}
$sql = "select * from members order by id";
$pager_option = array(
       "sql" => $sql,
       "sql" => $sql,
       "sql" => $sql,
   > $page
);

if ( isset($_GET['numItems']) )

{
   $pager_option['numItems'] = (int)$_GET['numItems'];
}
$pager = @new MemberPager($pager_option);
$pager->showMemberList();

?>

 

第二個需要說明的地方就是不同資料庫的兼容性,在不同的資料庫裡截獲一段結果的寫法是不一樣的。

mysql: select * from table limit offset, rowspgsql: select * from table limit m offset n......所以要在類別裡邊取得結果的時候需要使用pear db類別的limitQuery方法。 ok,寫完收功,希望花時間看完這些文字的你不覺得是浪費了時間。  

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/314945.htmlTechArticle1、前言分頁顯示是一種非常常見的瀏覽和顯示大量資料的方法,屬於web程式設計中最常處理的事件之一。對於web程式設計的老手來說,寫這種代...
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

為什麼我們評論:PHP指南 為什麼我們評論:PHP指南 Jul 15, 2025 am 02:48 AM

PHPhasthreecommentstyles://,#forsingle-lineand/.../formulti-line.Usecommentstoexplainwhycodeexists,notwhatitdoes.MarkTODO/FIXMEitemsanddisablecodetemporarilyduringdebugging.Avoidover-commentingsimplelogic.Writeconcise,grammaticallycorrectcommentsandu

如何在Windows上安裝PHP 如何在Windows上安裝PHP Jul 15, 2025 am 02:46 AM

安裝PHP在Windows上的關鍵步驟包括:1.下載合適的PHP版本並解壓,推薦使用ThreadSafe版本配合Apache或NonThreadSafe版本配合Nginx;2.配置php.ini文件,將php.ini-development或php.ini-production重命名為php.ini;3.將PHP路徑添加到系統環境變量Path中以便命令行使用;4.測試PHP是否安裝成功,通過命令行執行php-v和運行內置服務器測試解析能力;5.若使用Apache,需在httpd.conf中配置P

什麼是PHP,它是用什麼? 什麼是PHP,它是用什麼? Jul 16, 2025 am 03:45 AM

PHPisaserver-sidescriptinglanguageusedforwebdevelopment,especiallyfordynamicwebsitesandCMSplatformslikeWordPress.Itrunsontheserver,processesdata,interactswithdatabases,andsendsHTMLtobrowsers.Commonusesincludeuserauthentication,e-commerceplatforms,for

您如何處理PHP中的文件操作(閱讀/寫作)? 您如何處理PHP中的文件操作(閱讀/寫作)? Jul 16, 2025 am 03:48 AM

tohandlefileoperationsinphp,useApprepreprunctions andModes.1.toreadafile,usefile_get_contents()forsmallfilesorfgets()inaloopforline by line-line-processing.2.towriteToafile,usefile_put_cte_contents(usefile_contents)(

您的第一個PHP腳本:實用介紹 您的第一個PHP腳本:實用介紹 Jul 16, 2025 am 03:42 AM

如何開始編寫第一個PHP腳本?首先設置本地開發環境,安裝XAMPP/MAMP/LAMP,使用文本編輯器,了解服務器運行原理。其次,創建一個名為hello.php的文件,輸入基本代碼並運行測試。第三,學習混合使用PHP與HTML以實現動態內容輸出。最後,注意常見錯誤如缺少分號、引用問題及文件擴展名錯誤,並開啟錯誤報告以便調試。

PHP語法:基礎知識 PHP語法:基礎知識 Jul 15, 2025 am 02:46 AM

PHP的基礎語法包括四個關鍵點:1.PHP標籤必須使用結束,推薦使用完整標籤;2.輸出內容常用echo和print,其中echo支持多參數且效率更高;3.註釋方式有//、#和//,用於提升代碼可讀性;4.每條語句必須以分號結尾,空格和換行不影響執行但影響可讀性。掌握這些基本規則有助於寫出清晰穩定的PHP代碼。

PHP 8安裝指南 PHP 8安裝指南 Jul 16, 2025 am 03:41 AM

在Ubuntu上安裝PHP8的步驟為:1.更新軟件包列表;2.安裝PHP8及基礎組件;3.檢查版本確認安裝成功;4.按需安裝額外模塊。 Windows用戶可下載ZIP包並解壓,隨後修改配置文件、啟用擴展並將路徑加入環境變量。 macOS用戶推薦使用Homebrew安裝,依次執行添加tap、安裝PHP8、設置默認版本及驗證版本等步驟。不同系統下安裝方式雖有差異,但流程清晰,根據用途選對方法即可。

python如果還有示例 python如果還有示例 Jul 15, 2025 am 02:55 AM

寫Python的ifelse語句關鍵在於理解邏輯結構與細節。 1.基礎結構是if條件成立執行一段代碼,否則執行else部分,else可選;2.多條件判斷用elif實現,順序執行且一旦滿足即停止;3.嵌套if用於進一步細分判斷,建議不超過兩層;4.簡潔場景可用三元表達式替代簡單ifelse。注意縮進、條件順序及邏輯完整性,才能寫出清晰穩定的判斷代碼。

See all articles