A. php顯示很多資料庫信息,如何自動分頁呢代碼
PHP代碼如下:
/*
Author:默默
Date :2006-12-03
*/
$page=isset($_GET['page'])?intval($_GET['page']):1; //這句就是獲取page=18中的page的值,假如不存在page,那麼頁數就是1。
$num=10; //每頁顯示10條數據
$db=mysql_connect("host","name","pass"); //創建資料庫連接
$select=mysql_select_db("db",$db); //選擇要操作的資料庫
/*
首先咱們要獲取資料庫中到底有多少數據,才能判斷具體要分多少頁,具體的公式就是
總數據數除以每頁顯示的條數,有餘進一。
也就是說10/3=3.3333=4 有餘數就要進一。
*/
$total=mysql_num_rows(mysql_query("select id from table")); //查詢數據的總數,id是資料庫中的一個自動賦值的欄位
$pagenum=ceil($total/$num); //獲得總頁數
//假如傳入的頁數參數大於總頁數,則顯示錯誤信息
If($page>$pagenum || $page == 0){
Echo "Error : Can Not Found The page .";
Exit;
}
$offset=($page-1)*$num; //獲取limit的第一個參數的值,假如第一頁則為(1-1)*10=0,第二頁為(2-1)*10=10。
$info=mysql_query("select name from table limit $offset,$num"); //獲取相應頁數所需要顯示的數據,name是數據里的一個欄位
While($it=mysql_fetch_array($info)){
Echo $it['name']."
";
} //顯示數據
For($i=1;$i<=$pagenum;$i++){
$show=($i!=$page)?"$i":"$i";
Echo $show." ";
}
/*顯示分頁信息,假如是當頁則顯示粗體的數字,其餘的頁數則為超連接,假如當前為第三頁則顯示如下
1 2 3 4 5 6
*/
?>
B. php 文章分頁(分頁符)
php的分頁跟asp有本質區別。。。asp一般用記錄記分。。php一般用sql語句分。
select * from 表 LIMIT 0,30
上面是顯示 0到 30條。即第一頁,每頁30條
select * from 表 LIMIT 30,60
顯示 30到60條。。即第二頁。。。
。。。。。。。。。。。。。
依次下去
C. php 分頁演算法
這是我以前用的分頁,你看看吧,希望能幫到你。
<html>
<head>
<title>分頁</title>
</head>
<body>
<table align="center" border="1" width="500">
<tr>
<td>編號</td>
<td>用戶名</td>
<td>密碼</td>
<td>郵箱</td>
</tr>
<?php
$conn=mysql_connect("localhost","root","");
mysql_set_charset("utf8",$conn);
$db = mysql_select_db("bbs",$conn);
$rs = mysql_query("select * from userInfo");
$totalRow = mysql_num_rows($rs);//總記錄數
$currentPage = $_GET["currentPage"];//當前頁
if($currentPage == null){
$currentPage = 1;
}
$pageSize = 3;//每頁顯示的記錄數
$first = ($currentPage-1)*$pageSize;//起始值
$last = $first + $pageSize;//結束值
$totalPage = ceil($totalRow / $pageSize);//總頁數
if($last > $totalRow)
{
$last = $totalRow;
}
for($i=$first;$i<$last;$i++)
{
mysql_data_seek($rs,$i);//定位游標
$row = mysql_fetch_array($rs);
echo "<tr>";
echo " <td>{$row[0]}</td>";
echo " <td>{$row[1]}</td>";
echo " <td>{$row[2]}</td>";
echo " <td>{$row[3]}</td>";
echo "</tr>";
}
mysql_free_result($rs);
mysql_close($conn);
?>
<tr>
<td colspan="4" align="center">
<?php
if($currentPage == 1)
{
echo "首頁上一頁";
}
else
{
?>
<a href="fenye.php?currentPage=1">首頁</a>
<a href="fenye.php?currentPage=<?php echo $currentPage-1 ?>">上一頁</a>
<?php
}
if($currentPage == $totalPage)
{
echo "下一頁尾頁";
}
else
{
?>
<a href="fenye.php?currentPage=<?php echo $currentPage+1 ?>">下一頁</a>
<a href="fenye.php?currentPage=<?php echo $totalPage ?>">尾頁</a>
<?php
}
?>
<td>
</tr>
</table>
</body>
</html>
D. php分頁原理,懂得的指教一下哈!
分頁的原理在所有的WEB語言幾乎都是差不多的!下面我來說說吧
如果你能好好研究我寫的東西,分頁將不再是問題
分頁有兩種情況
一、文件數據的分頁
二、資料庫數據的分頁
其中資料庫數據的分頁用得最多,原理也是差不多,只不過獲得數據的方法不同。
下面主要說一下資料庫數據的分頁
首先我們要明白見個量
a、頁面上要顯示的鏈接數$links(我們這里討論的不是只有上一頁和下一頁的情形,我們討論網路圖片中的分頁效果)
b、每一頁要顯示的記錄數$page_messages即一頁中顯示的數據的多少
c、當前的頁碼$page
d、資料庫中總的記錄數(不是必要,但是為保證生成分頁條正確,我們也應該考慮)
有了上面的四個量我們就可以通過他們得出分頁條的開始頁碼和結束頁碼,以及
select * from tables where fields=value limit offset,numbers中的offset和numbers
其中offset=($page-1)*$page_messages
numbers=$page_messages
其次,我們要明白在點擊分頁條中的鏈接時我們應該將相應的頁碼傳遞到後台去
即$page傳遞PHP文件,通過它來動態的生成offset,重新從數據中讀取數據
最後,在模板文件中或者直接在HTML中通過循環控制語句,將數據顯示出來
分頁條中頁碼的計算須要考慮多方面,這里不做詳述,我會在最後給你一個分頁的源碼,由於這個分頁的源碼是用面向對象寫的,所以有點難,不過你只需會用這個類的最後一個方法理解它的每一個參數就可以實現分頁.
這個分布類用到一個數據操作類所以一並給出
<?php
header("content-type:text/html;charset=utf-8");
class DB{
static private $obj = null;
static private $db_link = null;
static private $dbhost;//資料庫伺服器地址
static private $dbuser;//資料庫用戶名
static private $dbpass;//資料庫密碼
static private $dbname;//資料庫名
static private $dbcharset;//資料庫編碼
static public function ConstZhi($host,$user,$password,$dbname,$dbcharset){
self::$dbhost=$host;
self::$dbuser=$user;
self::$dbpass=$password;
self::$dbname=$dbname;
self::$dbcharset=$dbcharset;
}
static public function &Instance(){
if ( null == self::$obj ){
$class = __CLASS__;
self::$obj = new $class;
}
return self::$obj;
}
function __construct(){
self::$db_link=mysql_connect(self::$dbhost,self::$dbuser,self::$dbpass);
@mysql_select_db(self::$dbname, self::$db_link ) or die("資料庫名錯誤,請查正!".mysql_error());
@mysql_query( 'SET NAMES '.self::$dbcharset,self::$db_link ) or die("編碼設置錯誤".mysql_error());
}
function __destruct(){
self::Close();
}
static public function Close(){
if ( is_resource( self::$db_link ) ){
@mysql_close( self::$db_link );
}
self::$db_link = null;
self::$obj = null;
}
static public function EscapeString( $string ){
self::Instance();
return @mysql_real_escape_string( $string, self::$db_link );
}
static public function GetInsertId(){
self::Instance();
return intval( @mysql_insert_id(self::$db_link) );
}
static public function Query( $sql ){
self::Instance();
$result = @mysql_query( $sql, self::$db_link );
if ( $result ){
return $result;
}
self::Close();
return false;
}
static public function doInsert( $table , $arr1 ){
$sql_fd = '';
$sql_v = '';
foreach ( $arr1 as $k => $v ) {
$sql_fd .= ", `$k` ";
$sql_v .= ", '".self::EscapeString( $v )."' ";
}
$sql_fd = '('.trim( $sql_fd , ',' ).')';
$sql_v = '('.trim($sql_v , ',').')';
$sql = "INSERT INTO `$table` ".$sql_fd.' VALUES '.$sql_v;
if ( mysql_query($sql) ) {
return mysql_insert_id();
}
return false;
}
static public function doDelete( $table , $val , $fd = 'id' ) {
self::Instance();
$sql = "DELETE FROM `$table` WHERE `$fd` = ".self::EscapeString($val) ;
return self::Query( $sql , self::$db_link );
}
/**
* doDeleteXu() made by xudianyang
* */
static public function doDeleteXu( $table , $val , $fd = 'id' ) {
self::Instance();
$sql = "DELETE FROM `$table` WHERE `$fd` = ".$val;
return self::Query( $sql , self::$db_link );
}
//UPDATE `sina`.`sohu_url` SET `state` = '1' WHERE `sohu_url`.`id` =1 LIMIT 1 ;
static public function doUpdate( $table , $arr1 , $arr2 ){
self::Instance();
$sql_set = '';
foreach ( $arr2 as $k => $v ) {
$sql_set .= ", `$k` = '".self::EscapeString($v)."' ";
}
$sql_set = trim( $sql_set , ',' );
$arr_w = array();
foreach ( $arr1 as $k => $v ){
$arr_w[] = " `".self::EscapeString($k)."` = '".self::EscapeString($v)."' ";
}
$sql = "UPDATE `$table` SET $sql_set WHERE ".implode('and' , $arr_w);
if ( self::Query($sql) )
return true;
return false;
}
static public function getRows( $table , $arr=array() , $one = 0 ) {
self::Instance();
if ( empty($arr) ){
$sql = "SELECT * FROM `$table`";
}else{
$arr_w = array();
foreach ( $arr as $k => $v ){
if(is_numeric($v))
$arr_w[] = " `".self::EscapeString($k)."` = ".self::EscapeString($v);
else
$arr_w[] = " `".self::EscapeString($k)."` = '".self::EscapeString($v)."' ";
}
$sql = "SELECT * FROM `$table` WHERE ".implode(' and' , $arr_w)." ORDER BY `id` ASC";
//echo $sql ;
}
if ( $ret = self::Query($sql) ){
if ( $one ){
return mysql_fetch_assoc( $ret );
}else{
$arr_out = array();
while( $row = mysql_fetch_assoc( $ret ) ){
$arr_out[] = $row;
}
return $arr_out;
}
}
return false;
}
static private function makeWhere( $arr ){
$arr_w = array();
foreach ( $arr as $k => $v ){
$arr_w[] = " `".self::EscapeString($k)."` = '".self::EscapeString($v)."' ";
}
return implode('and' , $arr_w);
}
static public function getCount( $table , $arr ){
if ( is_array($arr) and count($arr) > 0 ) {
$sql = "SELECT COUNT(*) n FROM `$table` WHERE ". self::makeWhere($arr);
if ( $ret = self::Query($sql) ){
$tmep = mysql_fetch_assoc( $ret );
return $tmep['n'];
}
}
return false;
}
/**
* getCountXu() made by xudianyang
* */
static public function getCountXu( $table , $arr ){
$sql = "SELECT COUNT(*) n FROM `$table`" ;
if ( $ret = self::Query($sql) ){
$tmep = mysql_fetch_assoc( $ret );
return $tmep['n'];
}
return false;
}
static public function getQueryResult( $sql, $one=false ){
$ret = array();
if ( $result = self::Query($sql) ){
while ( $row = mysql_fetch_assoc($result) ){
//$row = array_change_key_case($row, CASE_LOWER);
if ( $one ){
$ret = $row;
break;
}else{
array_push( $ret, $row );
}
}
@mysql_free_result( $result );
}
return $ret;
}
}
可以在類中配置你自己的資料庫伺服器相應的賬號和密碼
<?php
class Fenye{
private $mDB;
public function __construct(DB $obj){
$this->mDB=$obj;
}
/**
* 計算總共的頁數
*
* @param string $table 表名
* @param array $conditon 查詢的條件
* @param integer $message_number 每頁顯示的記錄數
* @return array */
public function getPageAll($table,$condition,$message_number){
if($condition == ""){
$recodernum=$this->mDB->getCountXu($table,$condition);
}else{
$recodernum=$this->mDB->getCount($table,$condition);
}
$arrnumber['all']=$recodernum;
$arrnumber['page_all']= ceil($recodernum/$message_number);
return $arrnumber;
}
/**
* 生成查詢的SQL語句
*
*@param string $table 需要查詢的表
*@param array $conditon 查詢的條件
*@param array $arr 查詢的欄位所組成的一個數組
*@param mixed $order 表示排序方式
*@param array $limit 表示指定查詢記錄的數目
*@return string
**/
public function createSQL($table,$condition,$arr,$order,$limit){
if ($table == ""){
return false;
}else{
$str1="";
$str2="";
$str3="";
$str4="";
$n=0;
$m=0;
$p=0;
if ($arr == ""){
$str1="*";
}else{
foreach ($arr as $value){
$p++;
if ($p == 1){
$str1.=$value;
}else{
$str1.=",".$value;
}
}
}
if($condition == ""){
$str2="";
}else{
foreach ($condition as $key => $value){
$n++;
if ($n == 1){
$str2.="where ".$key."="."'".$value."'";
}else{
$str2.=" and ".$key."="."'".$value."'";
}
}
}
if($order == ""){
$str3="";
}else{
foreach ($order as $key => $value){
$m++;
if ($m == 1){
$str3.=" order by ".$key." ".$value;
}else{
$str3.=",".$key." ".$value;
}
}
}
if ($limit == ""){
$str4="";
}else{
$str4="limit ".$limit[0].",".$limit[1];
}
$sql="select ".$str1." from ".$table." ".$str2.$str3." ".$str4;
}
return $sql;
}
/**
*獲取當前頁面應有的信息
*
*@param integer $page 當前的頁碼
*@param integer $message_number 每頁顯示的記錄數
*@param integer $pageall 總共的頁數
*@param string $sql 待執行的SQL語句
*@return array
*/
public function getPageInformation($page,$page_all,$message_number,$sql){
$start=0;//開始的頁碼
$end=0;//結束的頁碼
$arr=array();//返回的結果儲存在這個數組中
$left=intval($message_number/2);
$start=$page-$left;
$end=$page+$left;
if($message_number <= $page_all){//判斷總的頁數是否大於每一頁的鏈接數
if($end <= $message_number){
$end=$message_number;
}
}else{
$end=$page_all;
}
if($start <= 0){
$start=1;
}
if($end >= $page_all){
$start=$page_all-$message_number+1;
if($start <= 0){
$start=1;
}
$end=$page_all;
}
if($page < 1){
$page=1;
$start=1;
if($page_all <= $message_number){
$end=$page_all;
}
$end=$message_number;
}
if($page >= $page_all){
$page=$page_all;
$start=$page-$message_number+1;
if($start <= 0){
$start=1;
}
$end=$page;
}
$result=$this->mDB->Query($sql);
if($result){
for(;;){
$=mysql_fetch_assoc($result);
if($){
$arr1[]=$;
}else{
break;
}
}
}
$arr['start']=$start;
$arr['end']=$end;
$arr['page_all']=$page_all;
$arr['page']=$page;
$arr['content']=@ $arr1;
return $arr;
}
/**
* 修改傳遞的頁碼使其合法
*
* @param integer $page 傳遞過來的頁碼
* @param integer $page_all 總的頁碼
* @return integer*/
public function checkPage($page,$page_all){
if($page < 1){
$page=1;
}
if($page >= $page_all){
$page=$page_all;
}
return $page;
}
/**
* 生成分頁條
*
* @param integer $page 當前頁碼
* @param integer $start 分頁條開始頁碼
* @param integer $end 分頁條結束的頁碼
* @param integer $page_all 總共頁碼數
* @param string $otherquery 需要傳遞的其他參數 如&string=Publisher
* @return string
* */
public function createFenYeTiao($page,$start,$end,$page_all,$otherquery=''){
$str="";
if($page == 1){
$str.='首頁'." ".'上一頁'." ";
}else{
$str.="<a href='?page=1".$otherquery."' target='_self'>".'首頁'."</a>"." ";
$str.="<a href='?page=".($page-1).$otherquery."' target='_self'>".'上一頁'."</a>"." ";
}
for($i=$start;$i<=$end;$i++){
if($page == $i){
$str.="<a href='?page=".$page.$otherquery."' target='_self'>".$page."</a>"." ";
}else{
$str.="<a href='?page=".$i.$otherquery."' target='_self'>[".$i."]</a>"." ";
}
}
if($page == $page_all){
$str.='下一頁'." ".'尾頁';
}else{
$str.="<a href='?page=".($page+1).$otherquery."' target='_self'>".'下一頁'."</a>"." ";
$str.="<a href='?page=".$page_all.$otherquery."' target='_self'>".'尾頁'."</a>"." ";
}
return $str;
}
/**
* 完成分頁所有操作
*
*@param string $table 需要查詢的表
*@param array $conditon 查詢的條件
*@param array $arrField 查詢的欄位所組成的一個數組
*@param mixed $order 表示排序方式
*@param integer $page 當前頁碼
*@param integer $mess_num 每頁顯示的記錄數
*@param integer $page_link 顯示的鏈接數目
*@param string $otherquery 點擊分頁頁碼時需要傳遞的其他參數,默認為空
*@return array 包括分頁條和從資料庫讀得的數據分別保存在索引為content和fenyetiao的兩個元素中,注意
*索引為content的元素為一個二維數組*/
public function FinishFenYe($table,$condition,$arrField,$order,$page,$mess_num,$page_link,$otherquery){
$allnumber=$this->getPageAll($table,"",$mess_num);
$page_all=$allnumber['page_all'];
$page=$this->checkPage($page,$page_all);
$limitoffet=($page-1)*$mess_num;
$limit=array($limitoffet,$mess_num);
$sql=$this->createSQL($table,$condition,$arrField,$order,$limit);
$resarr=$this->getPageInformation($page,$page_all,$page_link,$sql);
$resarr['page']=$this->checkPage($resarr['page'],$resarr['page_all']);
$fenyetiao=$this->createFenYeTiao($resarr['page'],$resarr['start'],$resarr['end'],$resarr['page_all'],$otherquery);
$resarr['fenyetiao']=$fenyetiao;
$resarr['all']=$allnumber['all'];
return $resarr;
}
}
?>
祝你成功!
E. php分頁代碼
?php<br
include("connection.php");
$perNumber=10;
//每頁顯示的記錄數
$page=$_GET['page'];
//獲得當前的頁面值
$count=mysql_query("select
count(*)
from
user");
//獲得記錄總數
$rs=mysql_fetch_array($count);
$totalNumber=$rs[0];
$totalPage=ceil($totalNumber/$perNumber);
//計算出總頁數
if
(!isset($page))
{
$page=1;
}
//如果沒有值,則賦值1
$startCount=($page-1)*$perNumber;
//分頁開始,根據此方法計算出開始的記錄
$result=mysql_query("select
*
from
user
limit
$startCount,$perNumber");
//根據前面的計算出開始的記錄和記錄數
while
($row=mysql_fetch_array($result))
{
echo
"user_id:".$row[0]."
";
echo
"username:".$row[1]."
";
//顯示資料庫的內容
}
if
($page
!=
1)
{
//頁數不等於1
?>
上一頁
顯示上一頁
?php<br
}
for
($i=1;$i<=$totalPage;$i++)
{
//循環顯示出頁面
?>
?php
echo
$i
;?
?php<br
}
if
($page<$totalPage)
{
//如果page小於總頁數,顯示下一頁鏈接
?>
下一頁
?php<br
}
?>
================================
這個是很簡單的..而且也寫了注釋..不知道合不合你的意..
F. Thinkphp數組分頁如何操作
第一種:利用Page類和limit方法
$User = M('User'); // 實例化User對象
import('ORG.Util.Page');// 導入分頁類
$count = $User->where('status=1')->count();// 查詢滿足要求的總記錄數
$Page = new Page($count,25);// 實例化分頁類 傳入總記錄數和每頁顯示的記錄數
$show = $Page->show();// 分頁顯示輸出
// 進行分頁數據查詢 注意limit方法的參數要使用Page類的屬性
$list = $User->where('status=1')->order('create_time')->limit($Page->firstRow.','.$Page->listRows)->select();
$this->assign('list',$list);// 賦值數據集
$this->assign('page',$show);// 賦值分頁輸出
$this->display(); // 輸出模板
第二種:分頁類和page方法的實現
$User = M('User'); // 實例化User對象
// 進行分頁數據查詢 注意page方法的參數的前面部分是當前的頁數使用 $_GET[p]獲取
$list = $User->where('status=1')->order('create_time')->page($_GET['p'].',25')->select();
$this->assign('list',$list);// 賦值數據集
import(「ORG.Util.Page」);// 導入分頁類
$count = $User->where('status=1')->count();// 查詢滿足要求的總記錄數
$Page = new Page($count,25);// 實例化分頁類 傳入總記錄數和每頁顯示的記錄數
$show = $Page->show();// 分頁顯示輸出
$this->assign('page',$show);// 賦值分頁輸出
$this->display(); // 輸出模板
帶入查詢條件
如果是POST方式查詢,如何確保分頁之後能夠保持原先的查詢條件呢,我們可以給分頁類傳入參數,方法是給分頁類的parameter屬性賦值:
import('ORG.Util.Page');// 導入分頁類
$mapcount = $User->where($map)->count();// 查詢滿足要求的總記錄數
$Page = new Page($count,25);// 實例化分頁類 傳入總記錄數和每頁顯示的記錄數
//分頁跳轉的時候保證查詢條件
foreach($map as $key=>$val) {
$Page->parameter .= "$key=".urlencode($val).'&';
}
$show = $Page->show();// 分頁顯示輸出
G. php分頁代碼 怎麼寫
Web開發是今後分布式程式開發的主流,通常的web開發都要涉及到與資料庫打交道,客戶端從伺服器端讀取通常都是以分頁的形式來顯示,一頁一頁的閱讀起來既方便又美觀。所以說寫分頁程序是web開發的一個重要組成部分,在這里,我們共同來研究分頁程序的編寫。
一、分頁程序的原理
分頁程序有兩個非常重要的參數:每頁顯示幾條記錄($pagesize)和當前是第幾頁($page)。有了這兩個參數就可以很方便的寫出分頁程序,我們以MySql資料庫作為數據源,在mysql里如果要想取出表內某段特定內容可以使用的 T-SQL語句:select * from table limit offset,rows來實現。這里的offset是記錄偏移量,它的計算方法是offset=$pagesize*($page-1),rows是要顯示的記錄條數,這里就是$page。也就是說select * from table limit 10,10這條語句的意思是取出表裡從第11條記錄開始的20條記錄。
二、主要代碼解析
$pagesize=10; //設置每一頁顯示的記錄數
$conn=mysql_connect("localhost","root",""); //連接資料庫
$rs=mysql_query("select count(*) from tb_proct",$conn); //取得記錄總數$rs
$myrow = mysql_fetch_array($rs);
$numrows=$myrow[0];
//計算總頁數
$pages=intval($numrows/$pagesize);
//判斷頁數設置
if (isset($_GET['page'])){
$page=intval($_GET['page']);
}
else{
$page=1; //否則,設置為第一頁
}
三、創建用例用表myTable
create table myTable(id int NOT NULL auto_increment,news_title varchar(50),news_cont text,add_time datetime,PRIMARY KEY(id))
四、完整代碼
<html>
<head>
<title>php分頁示例</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<?php
$conn=mysql_connect("localhost","root","");
//設定每一頁顯示的記錄數
$pagesize=1;
mysql_select_db("mydata",$conn);
//取得記錄總數$rs,計算總頁數用
$rs=mysql_query("select count(*) from tb_proct",$conn);
$myrow = mysql_fetch_array($rs);
$numrows=$myrow[0];
//計算總頁數
$pages=intval($numrows/$pagesize);
if ($numrows%$pagesize)
$pages++;
//設置頁數
if (isset($_GET['page'])){
$page=intval($_GET['page']);
}
else{
//設置為第一頁
$page=1;
}
//計算記錄偏移量
$offset=$pagesize*($page - 1);
//讀取指定記錄數
$rs=mysql_query("select * from myTable order by id desc limit $offset,$pagesize",$conn);
if ($myrow = mysql_fetch_array($rs))
{
$i=0;
?>
<table border="0" width="80%">
<tr>
<td width="50%" bgcolor="#E0E0E0">
<p align="center">標題</td>
<td width="50%" bgcolor="#E0E0E0">
<p align="center">發布時間</td>
</tr>
<?php
do {
$i++;
?>
<tr>
<td width="50%"><?=$myrow["news_title"]?></td>
<td width="50%"><?=$myrow["news_cont"]?></td>
</tr>
<?php
}
while ($myrow = mysql_fetch_array($rs));
echo "</table>";
}
echo "<div align='center'>共有".$pages."頁(".$page."/".$pages.")";
for ($i=1;$i< $page;$i++)
echo "<a href='fenye.php?page=".$i."'>[".$i ."]</a> ";
echo "[".$page."]";
for ($i=$page+1;$i<=$pages;$i++)
echo "<a href='fenye.php?page=".$i."'>[".$i ."]</a> ";
echo "</div>";
?>
</body>
</html>
五、總結
本例代碼在windows2000 server+php4.4.0+mysql5.0.16上運行正常。該示例顯示的分頁格式是[1][2][3]…這樣形式。假如想顯示成「首頁 上一頁 下一頁 尾頁」這樣形式,請加入以下代碼:
$first=1;
$prev=$page-1;
$next=$page+1;
$last=$pages;
if ($page > 1)
{
echo "<a href='fenye.php?page=".$first."'>首頁</a> ";
echo "<a href='fenye.php?page=".$prev."'>上一頁</a> ";
}
if ($page < $pages)
{
echo "<a href='fenye.php?page=".$next."'>下一頁</a>
echo "<a href='fenye.php?page=".$last."'>尾頁</a> ";
}
其實,寫分頁顯示代碼是很簡單的,只要掌握了它的工作原理。希望這篇文章能夠帶給那些需要這方面程序web程序員的幫助。
H. 求php數字分頁演算法
假設。
你只需要顯示當前頁數的前3頁和後3頁。
吶么只有3種可能。
第一個可能,用戶當前點擊的頁數未超過前3頁。需要顯示前7頁(前三頁和後三頁以及當前點擊的頁)省略7頁後面的頁。
第二個可能,用戶點擊的頁數以超過前三頁可是未到尾三頁。那麼就要省略當前頁數的前三頁後三頁之外的所有頁碼。
第三個可能,用戶點擊的頁數以超過尾三頁。那麼就省略最後7頁外的所有頁碼。
這是我寫的分頁碼中算省略頁碼的代碼。
$fornum = 10; //先聲明你要顯示的是幾個頁。
if($totalpage > $fornum) //判斷當前的所有頁數是否超過你要顯示的頁。如果沒超過。那就不用費事直接顯示所有頁碼就行叻。 如果超過進入循環。
{
//第一種可能。我這個是只顯示10個頁碼。
if($page<=6) //如果當前的頁碼大於等於6.也就是前面的頁碼不用省略。直接省略10個頁碼之後的頁就OK叻。
{
for($i=1; $i <= $fornum; $i++)//這就是循環顯示數字頁碼
{
if($page == $i ){
echo '<a href="javascript:;" class="on">'.$i.'</a>';
}
else{
echo '<a href="'.$_SERVER['PHP_SELF'].'?page='.$i.'" class="num">'.$i.'</a>';
}
}
echo '<a href="'.$_SERVER['PHP_SELF'].'?page='.$totalpage.'" class="num">...'.$totalpage.'</a>';
}
//注意阿。這不是第二個可能。這是第三個可能。因為第一個和第三個好判斷。而兩個都不滿足吶就是第二個可能叻。所以第二個不用判斷。這個條件也很好解釋。總的頁數減去當前頁數小於等於5的話。那麼就省略最後10頁以外的頁碼。
elseif(($totalpage-$page) <= 5)
{
echo '<a href="'.$_SERVER['PHP_SELF'].'?page=1" class="num">1...</a>';
for($i=$totalpage - ($fornum -1); $i <= $totalpage; $i++)//依舊是循環顯示數字頁碼
{
if($page == $i ){
echo '<a href="javascript:;" class="on">'.$i.'</a>';
}
else{
echo '<a href="'.$_SERVER['PHP_SELF'].'?page='.$i.'" class="num">'.$i.'</a>';
}
}
}
//這就是第二個可能叻。第一和第三的條件都不滿足那麼只有前沒到頭後沒著尾的情況叻。所以不用判斷直接顯示當前頁數的前幾頁和後幾頁。頭尾都省略。
else
{
echo '<a href="'.$_SERVER['PHP_SELF'].'?page=1" class="num">1...</a>';
for($i=$page - 4; $i < $page + 5; $i++)//循環顯示數字頁碼
{
if($page == $i ){
echo '<a href="javascript:;" class="on">'.$i.'</a>';
}
else{
echo '<a href="'.$_SERVER['PHP_SELF'].'?page='.$i.'" class="num">'.$i.'</a>';
}
}
echo '<a href="'.$_SERVER['PHP_SELF'].'?page='.$totalpage.'" class="num">...'.$totalpage.'</a>';
}
}
//這是最上面的那個if的,如果總頁碼沒超過你要顯示的頁碼就直接顯示所有的頁碼~
else
{
for($i=1; $i <= $totalpage; $i++)//仍是循環顯示數字頁碼
{
if($page == $i ){
echo '<a href="javascript:;" class="on">'.$i.'</a>';
}
else{
echo '<a href="'.$_SERVER['PHP_SELF'].'?page='.$i.'" class="num">'.$i.'</a>';
}
}
}
然後就木有叻。首頁尾頁上頁下頁的代碼我就不粘叻。 關於顯示固定頁碼的代碼就是這些。希望你能看懂。打的我手都酸了。。。
I. PHP分頁問題. 望大蝦開示
1.$_GET[page] 是你點擊 上一頁 或者 下一頁 傳遞過來的, 當你的頁面初始化的時候 也就是你沒還沒點擊上一頁 下一頁 的時候 他應該是0
2.$page.=','; 這個的意思是 $page = $page . ','; 他是用來拼寫SQL 語句的
拼寫後 你的SQL 應該是 select * from message limit 0,5; 注意看 0 和之間 有個 逗號 代表 從結果集的第一行數據 往下取5 行
3.分頁其實非常簡單 比如說你有26記錄 每5條為一頁 26條記錄能分幾頁啊 ? 當然是 6頁了...
可是計算機不知道 你就給他一個演算法
記住公式 (總的記錄條數 + 每頁的記錄數 - 1) / 每頁的記錄數
咱們用公式算一下 (26 + 5 -1) / 5 = 6
然後我們看下SQL $sql="select * from message limit $page $pagesize ";
第1頁的時候 是 limit 0,5
第2頁的時候 是 limit 5,5
第2頁的時候 是 limit 10,5
剛才也說了 limit 是從第幾行數據 往下 走 幾行 因為咱們是 5條數據一分也所以 第2個參數永遠都不用變就是5 ,第一個參數 非常好算 每頁的記錄數 * (當前頁數 - 1)
第1頁的時候 是 5*(1-1)=0
第2頁的時候 是 5*(2-1)=5
第1頁的時候 是 5*(3-1)=10
還有說的就是你的代碼 問題很嚴重 . php 5.3 版本 你這程序根本就運行不了....
$_GET['page'] 這個樣寫才標准. 不要以為PHP 單引號 和 雙引號 沒有任何差別 單引號的速度要比 雙引號 快3倍. $_GET[page] 這種寫法 5.3 以後直接就報錯了. 建議你馬上升級為5.3 或更高的版本 養成一個練好的編寫代碼習慣.