麻辣家族討論版版's Archiver

小誌 發表於 2011-4-20 10:52

8-3-2 建立分頁選擇

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

小誌 發表於 2011-4-20 10:54

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

小誌 發表於 2011-4-20 10:54

ex08_22.php[code]<?
    $conn = mysql_connect("localhost", "root", "12345a");
    if(@mysql_select_db("STUDENTS", $conn))
     {
      //指定提取資料的校對字元表
      mysql_query("set character set big5");
      //資料庫存在,建立SQL命令字串
      $SQL="SELECT * FROM studentlist";
      //將回傳結果存放於變數中
      $datalist=mysql_query($SQL);
      //取得欄位數量
      $fieldnum=mysql_num_fields($datalist);
      //取得資料錄數量
      $rowsnum=mysql_num_rows($datalist);
      //計算總共有多少分頁
      if (($rowsnum / 10) >intval($rowsnum / 10))
       {
        $TotalPage=intval($rowsnum / 10)+1;
       }
      else
       {
        $TotalPage=intval($rowsnum / 10);
       }
      

//決定開始顯示的分頁
//若未指定分頁則預設顯示第一頁
if (! isset($_REQUEST["ToPage"]))
{
  $GoPage=1;
}
//若指定分頁數小於1則預設顯示第一頁
else if ($_REQUEST["ToPage"]<1)
{
  $GoPage=1;
}
//若指定指定的分頁超過總分頁數則顯示最後一頁
else if ($_REQUEST["ToPage"]>$TotalPage)
{
  $GoPage=$TotalPage;
}
else
{
$GoPage=$_REQUEST["ToPage"];
}
//將作用中資料錄位置移到分頁的第一筆資料錄上來開始顯示內容
  mysql_data_seek($datalist,($GoPage-1)*10);      
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=big5">
<title>範例ex08_22</title>
</head><body>
<?="共$rowsnum 筆資料;共$TotalPage 張分頁";?><p><center>

<?
for ($I=1; $I<=$TotalPage; $I++)
{
//如果非正在顯示的分頁則建立頁碼連結
   IF ($I != $GoPage )
      {
      $myURL=$_SERVER["PHP_SELF"] . "?ToPage=";
      echo "<a href=" . $myURL . $I . ">" . $I . "</a>|" ;
      }
//如果是正在顯示的方頁則單純顯示頁碼
   else
      {
      echo $I . "|" ;
      }
}
?>

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

      for ($y=0;$y<10;$y++)  
          {
             //將資料錄轉換為欄位陣列集合
            $fielddatas=mysql_fetch_array($datalist);
             //輸出欄位資料
             echo "<tr>";
             for ($x=0;$x<$fieldnum;$x++)
                {
                 echo "<td>" . $fielddatas[$x] . "</td>";
                }
             echo "</tr>";  
          }
?>
<table></body>
</html>
<?
     }
    else
     {
      echo "資料庫不存在";
     }
?>[/code]

頁: [1]

麻辣家族討論版版為 麻辣學園 網站成員  由 昱得資訊工作室 © Since 1993 所提供