php本身是沒有分頁概念的,分頁是URL傳參,然后通過mysql查詢語句到數(shù)據(jù)庫獲取數(shù)據(jù),然后實(shí)現(xiàn)的分頁,url上的參數(shù),通過PHP的$_GET都是可以獲取到的。
瓦房店網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。成都創(chuàng)新互聯(lián)2013年開創(chuàng)至今到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)。
現(xiàn)在市面上的PHP框架基本都有PHP分頁類,參照文檔直接調(diào)用就好了,如果想看實(shí)現(xiàn)過程,可以去下載一個TP框架,然后打開里面的分頁類查看里面的源代碼。
?php
class?Page?{
private?$total;?//數(shù)據(jù)表中總記錄數(shù)
private?$listRows;?//每頁顯示行數(shù)
private?$limit;
private?$uri;
private?$pageNum;?//頁數(shù)
private?$config=array('header'="個記錄",?"prev"="上一頁",?"next"="下一頁",?"first"="首?頁",?"last"="尾?頁");
private?$listNum=8;
/*
*?$total?
*?$listRows
*/
public?function?__construct($total,?$listRows=10,?$pa=""){
$this-total=$total;
$this-listRows=$listRows;
$this-uri=$this-getUri($pa);
$this-page=!empty($_GET["page"])???$_GET["page"]?:?1;
$this-pageNum=ceil($this-total/$this-listRows);
$this-limit=$this-setLimit();
}
private?function?setLimit(){
return?"Limit?".($this-page-1)*$this-listRows.",?{$this-listRows}";
}
private?function?getUri($pa){
$url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"],?'?')?'':"?").$pa;
$parse=parse_url($url);
if(isset($parse["query"])){
parse_str($parse['query'],$params);
unset($params["page"]);
$url=$parse['path'].'?'.http_build_query($params);
}
return?$url;
}
private?function?__get($args){
if($args=="limit")
return?$this-limit;
else
return?null;
}
private?function?start(){
if($this-total==0)
return?0;
else
return?($this-page-1)*$this-listRows+1;
}
private?function?end(){
return?min($this-page*$this-listRows,$this-total);
}
private?function?first(){
if($this-page==1)
$html.='';
else
$html.="nbsp;nbsp;a?href='javascript:setPage(\"{$this-uri}page=1\")'{$this-config["first"]}/anbsp;nbsp;";
return?$html;
}
private?function?prev(){
if($this-page==1)
$html.='';
else
$html.="nbsp;nbsp;a?href='javascript:setPage(\"{$this-uri}page=".($this-page-1)."\")'{$this-config["prev"]}/anbsp;nbsp;";
return?$html;
}
private?function?pageList(){
$linkPage="";
$inum=floor($this-listNum/2);
for($i=$inum;?$i=1;?$i--){
$page=$this-page-$i;
if($page1)
continue;
$linkPage.="nbsp;a?href='javascript:setPage(\"{$this-uri}page={$page}\")'{$page}/anbsp;";
}
$linkPage.="nbsp;{$this-page}nbsp;";
for($i=1;?$i=$inum;?$i++){
$page=$this-page+$i;
if($page=$this-pageNum)
$linkPage.="nbsp;a?href='javascript:setPage(\"{$this-uri}page={$page}\")'{$page}/anbsp;";
else
break;
}
return?$linkPage;
}
private?function?next(){
if($this-page==$this-pageNum)
$html.='';
else
$html.="nbsp;nbsp;a?href='javascript:setPage(\"{$this-uri}page=".($this-page+1)."\")'{$this-config["next"]}/anbsp;nbsp;";
return?$html;
}
private?function?last(){
if($this-page==$this-pageNum)
$html.='';
else
$html.="nbsp;nbsp;a?href='javascript:setPage(\"{$this-uri}page=".($this-pageNum)."\")'{$this-config["last"]}/anbsp;nbsp;";
return?$html;
}
private?function?goPage(){
return?'nbsp;nbsp;input?type="text"?onkeydown="javascript:if(event.keyCode==13){var?page=(this.value'.$this-pageNum.')?'.$this-pageNum.':this.value;setPage(\''.$this-uri.'page=\'+page+\'\')}"?value="'.$this-page.'"?style="width:25px"input?type="button"?value="GO"?onclick="javascript:var?page=(this.previousSibling.value'.$this-pageNum.')?'.$this-pageNum.':this.previousSibling.value;setPage(\''.$this-uri.'page=\'+page+\'\')"nbsp;nbsp;';
}
function?fpage($display=array(0,1,2,3,4,5,6,7,8)){
$html[0]="nbsp;nbsp;共有b{$this-total}/b{$this-config["header"]}nbsp;nbsp;";
$html[1]="nbsp;nbsp;每頁顯示b".($this-end()-$this-start()+1)."/b條,本頁b{$this-start()}-{$this-end()}/b條nbsp;nbsp;";
$html[2]="nbsp;nbsp;b{$this-page}/{$this-pageNum}/b頁nbsp;nbsp;";
$html[3]=$this-first();
$html[4]=$this-prev();
$html[5]=$this-pageList();
$html[6]=$this-next();
$html[7]=$this-last();
$html[8]=$this-goPage();
$fpage='';
foreach($display?as?$index){
$fpage.=$html[$index];
}
return?$fpage;
}
}
PHP代碼如下:
/*
Author:默默
Date :2006-12-03
*/
$page=isset($_GET['page'])?intval($_GET['page']):1; //這句就是獲取page=18中的page的值,假如不存在page,那么頁數(shù)就是1。
$num=10; //每頁顯示10條數(shù)據(jù)
$db=mysql_connect("host","name","pass"); //創(chuàng)建數(shù)據(jù)庫連接
$select=mysql_select_db("db",$db); //選擇要操作的數(shù)據(jù)庫
/*
首先咱們要獲取數(shù)據(jù)庫中到底有多少數(shù)據(jù),才能判斷具體要分多少頁,具體的公式就是
總數(shù)據(jù)數(shù)除以每頁顯示的條數(shù),有余進(jìn)一。
也就是說10/3=3.3333=4 有余數(shù)就要進(jìn)一。
*/
$total=mysql_num_rows(mysql_query("select id from table")); //查詢數(shù)據(jù)的總數(shù),id是數(shù)據(jù)庫中的一個自動賦值的字段
$pagenum=ceil($total/$num); //獲得總頁數(shù)
//假如傳入的頁數(shù)參數(shù)大于總頁數(shù),則顯示錯誤信息
If($page$pagenum || $page == 0){
Echo "Error : Can Not Found The page .";
Exit;
}
$offset=($page-1)*$num; //獲取limit的第一個參數(shù)的值,假如第一頁則為(1-1)*10=0,第二頁為(2-1)*10=10。
$info=mysql_query("select name from table limit $offset,$num"); //獲取相應(yīng)頁數(shù)所需要顯示的數(shù)據(jù),name是數(shù)據(jù)里的一個字段
While($it=mysql_fetch_array($info)){
Echo $it['name']."
";
} //顯示數(shù)據(jù)
For($i=1;$i=$pagenum;$i++){
$show=($i!=$page)?"$i":"$i";
Echo $show." ";
}
/*顯示分頁信息,假如是當(dāng)頁則顯示粗體的數(shù)字,其余的頁數(shù)則為超連接,假如當(dāng)前為第三頁則顯示如下
1 2 3 4 5 6
*/
?
這個網(wǎng)上太多相關(guān)的資料了 你自己動手搜搜
主要靠sql語句控制
如