Board logo

標題: 8-3-2 建立分頁選擇 [打印本頁]

作者: 小誌    時間: 2011-4-20 10:52     標題: 8-3-2 建立分頁選擇

8-3-2   建立分頁選擇
為了讓使用者自己指定想要觀看的分頁內容,即在瀏覽器中附加參數傳遞給我們的程式:(ToPage參數值即使用者想觀看的分頁頁碼)
  1. http://localhost/php/ch8/ex08_22.php?ToPage=19
複製代碼
上例中「ToPage=19」即代表使用者想觀看的是第19個分頁的資料,因此我們就必須使用「mysql_data_seek()」函數,到指定頁數要顯示的第一筆資料錄上,也就是指定目前「作用中」資料錄要移到哪一個分頁的第一筆資料錄上來開始顯示內容。
由於使用者可在網址列自行輸入ToPage參數值,因此我們去需作一些預防措施,防止使用者指定了不正確的分頁頁碼:
  1. //決定開始顯示的分頁
  2. //若未指定分頁則預設顯示第一頁
  3. if (! isset($_REQUEST["ToPage"]))
  4. {
  5.   $GoPage=1;
  6. }
  7. //若指定分頁數小於1則預設顯示第一頁
  8. else if ($_REQUEST["ToPage"]<1)
  9. {
  10.   $GoPage=1;
  11. }
  12. //若指定指定的分頁超過總分頁數則顯示最後一頁
  13. else if ($_REQUEST["ToPage"]>$TotalPage)
  14. {
  15.   $GoPage=$TotalPage;
  16. }
  17. else
  18. {
  19. $GoPage=$_REQUEST["ToPage"];
  20. }
  21. //將作用中資料錄位置移到分頁的第一筆資料錄上來開始顯示內容
  22.   mysql_data_seek($datalist,($GoPage-1)*10);
複製代碼

作者: 小誌    時間: 2011-4-20 10:54

分頁的數量很多,該如何讓使用者在網頁中點選呢?方法非常簡單,直接使用For迴圈來輸出頁碼連結即可:
  1. <?
  2. for ($I=1; $I<=$TotalPage; $I++)
  3. {
  4. //如果非正在顯示的分頁則建立頁碼連結
  5.    IF ($I != $GoPage )
  6.       {
  7.       $myURL=$_SERVER["PHP_SELF"] . "?ToPage=";
  8.       echo "<a href=" . $myURL . $I . ">" . $I . "</a>|" ;
  9.       }
  10. //如果是正在顯示的方頁則單純顯示頁碼
  11.    else
  12.       {
  13.       echo $I . "|" ;
  14.       }
  15. }
  16. ?>
複製代碼
上例中的「$_SERVER["PHP_SELF"]」,是利用_SERVER陣列變數物件取得環境變數「PHP_SELF」的值,也就是取得程式網頁本身的網址,將取得的網址資料加上ToPage參數的組合成超連結設定,就可以讓使用者點選而顯示使用者自己想觀看的分頁內容。
[attach]5654[/attach]
圖8-25  範例ex08_22。
作者: 小誌    時間: 2011-4-20 10:54

ex08_22.php
  1. <?
  2.     $conn = mysql_connect("localhost", "root", "12345a");
  3.     if(@mysql_select_db("STUDENTS", $conn))
  4.      {
  5.       //指定提取資料的校對字元表
  6.       mysql_query("set character set big5");
  7.       //資料庫存在,建立SQL命令字串
  8.       $SQL="SELECT * FROM studentlist";
  9.       //將回傳結果存放於變數中
  10.       $datalist=mysql_query($SQL);
  11.       //取得欄位數量
  12.       $fieldnum=mysql_num_fields($datalist);
  13.       //取得資料錄數量
  14.       $rowsnum=mysql_num_rows($datalist);
  15.       //計算總共有多少分頁
  16.       if (($rowsnum / 10) >intval($rowsnum / 10))
  17.        {
  18.         $TotalPage=intval($rowsnum / 10)+1;
  19.        }
  20.       else
  21.        {
  22.         $TotalPage=intval($rowsnum / 10);
  23.        }
  24.       

  25. //決定開始顯示的分頁
  26. //若未指定分頁則預設顯示第一頁
  27. if (! isset($_REQUEST["ToPage"]))
  28. {
  29.   $GoPage=1;
  30. }
  31. //若指定分頁數小於1則預設顯示第一頁
  32. else if ($_REQUEST["ToPage"]<1)
  33. {
  34.   $GoPage=1;
  35. }
  36. //若指定指定的分頁超過總分頁數則顯示最後一頁
  37. else if ($_REQUEST["ToPage"]>$TotalPage)
  38. {
  39.   $GoPage=$TotalPage;
  40. }
  41. else
  42. {
  43. $GoPage=$_REQUEST["ToPage"];
  44. }
  45. //將作用中資料錄位置移到分頁的第一筆資料錄上來開始顯示內容
  46.   mysql_data_seek($datalist,($GoPage-1)*10);      
  47. ?>
  48. <html>
  49. <head>
  50. <meta http-equiv="Content-Type" content="text/html; charset=big5">
  51. <title>範例ex08_22</title>
  52. </head><body>
  53. <?="共$rowsnum 筆資料;共$TotalPage 張分頁";?><p><center>

  54. <?
  55. for ($I=1; $I<=$TotalPage; $I++)
  56. {
  57. //如果非正在顯示的分頁則建立頁碼連結
  58.    IF ($I != $GoPage )
  59.       {
  60.       $myURL=$_SERVER["PHP_SELF"] . "?ToPage=";
  61.       echo "<a href=" . $myURL . $I . ">" . $I . "</a>|" ;
  62.       }
  63. //如果是正在顯示的方頁則單純顯示頁碼
  64.    else
  65.       {
  66.       echo $I . "|" ;
  67.       }
  68. }
  69. ?>

  70. <center><table border=1 width=100%>
  71. <?
  72. /**************列出欄位抬頭***************/
  73. echo "<tr>";     
  74.       for ($x=0 ;$x<$fieldnum;$x++)
  75.          {
  76.           echo "<td>" . mysql_field_name($datalist,$x) . "</td>";
  77.          }
  78. echo "</tr>";   
  79. /**************列出欄位資料***************/

  80.       for ($y=0;$y<10;$y++)  
  81.           {
  82.              //將資料錄轉換為欄位陣列集合
  83.             $fielddatas=mysql_fetch_array($datalist);
  84.              //輸出欄位資料
  85.              echo "<tr>";
  86.              for ($x=0;$x<$fieldnum;$x++)
  87.                 {
  88.                  echo "<td>" . $fielddatas[$x] . "</td>";
  89.                 }
  90.              echo "</tr>";  
  91.           }
  92. ?>
  93. <table></body>
  94. </html>
  95. <?
  96.      }
  97.     else
  98.      {
  99.       echo "資料庫不存在";
  100.      }
  101. ?>
複製代碼





歡迎光臨 麻辣家族討論版版 (http://forum.twbts.com/)