漂亮的php數(shù)據(jù)分頁類 php分頁函數(shù)封裝

PHP怎么制作分頁

方法/步驟

創(chuàng)新互聯(lián)是一家專業(yè)提供黃浦企業(yè)網(wǎng)站建設,專注與網(wǎng)站設計制作、網(wǎng)站建設H5技術、小程序制作等業(yè)務。10年已為黃浦眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進行中。

首先要了解下分頁的原理即

SELECT * FROM table …… limit 開始位置 , 操作條數(shù)

開始位置從0開始

SELECT * FROM table …… limit 0 , 20

取最前面20條

SELECT * FROM table …… limit 10 , 20

11條到20條

其次分頁要用的公式

得到公式

(當前頁數(shù) - 1 )X 每頁條數(shù) , 每頁條數(shù)

Select * from table limit ($Page- 1) * $PageSize, $PageSize

還要了解parse_url()解析URL函數(shù)

parse_url() 是講URL解析成有固定鍵值的數(shù)組的函數(shù)

$ua=parse_url("");

print_r($ua);

結果:

Array

(

[scheme] = http

[host] = hostname

[user] = username

[pass] = password

[path] = /path

[query] = arg=value

[fragment] = anchor

)

創(chuàng)建數(shù)據(jù)庫bbs和表test有

CREATE TABLE `test` (

`id` int(11) NOT NULL auto_increment,

`name` varchar(50) character set gb2312 NOT NULL,

`sex` varchar(2) character set gb2312 NOT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=11 ;

然后插入十幾條測試數(shù)據(jù)即可

寫mysql數(shù)據(jù)庫連接代碼保存conn.php文件里

代碼如下

?php

$conn = @ mysql_connect("localhost", "root", "") or die("數(shù)據(jù)庫鏈接錯誤");

mysql_select_db("bbs", $conn);

mysql_query("set names 'GBK'"); //使用GBK中文編碼;

function htmtocode($content) {

$content = str_replace("\n", "br", str_replace(" ", " ", $content));

return $content;

}

//$content=str_replace("'","'",$content);

//htmlspecialchars();

?

寫分頁函數(shù)page.php

代碼如下

?php

function _PAGEFT($totle, $displaypg = 20, $url = '') {

global $page, $firstcount, $pagenav, $_SERVER;

$GLOBALS["displaypg"] = $displaypg;

if (!$page)

$page = 1;

if (!$url) {

$url = $_SERVER["REQUEST_URI"];

}

//URL分析:

$parse_url = parse_url($url);

$url_query = $parse_url["query"]; //單獨取出URL的查詢字串

if ($url_query) {

$url_query = ereg_replace("(^|)page=$page", "", $url_query);

$url = str_replace($parse_url["query"], $url_query, $url);

if ($url_query)

$url .= "page";

else

$url .= "page";

} else {

$url .= "?page";

}

$lastpg = ceil($totle / $displaypg); //最后頁,也是總頁數(shù)

$page = min($lastpg, $page);

$prepg = $page -1; //上一頁

$nextpg = ($page == $lastpg ? 0 : $page +1); //下一頁

$firstcount = ($page -1) * $displaypg;

//開始分頁導航條代碼:

$pagenav = "顯示第 B" . ($totle ? ($firstcount +1) : 0) . "/B-B" . min($firstcount + $displaypg, $totle) . "/B 條記錄,共 $totle 條記錄";

//如果只有一頁則跳出函數(shù):

if ($lastpg = 1)

return false;

$pagenav .= " a href='$url=1'首頁/a ";

if ($prepg)

$pagenav .= " a href='$url=$prepg'前頁/a ";

else

$pagenav .= " 前頁 ";

if ($nextpg)

$pagenav .= " a href='$url=$nextpg'后頁/a ";

else

$pagenav .= " 后頁 ";

$pagenav .= " a href='$url=$lastpg'尾頁/a ";

//下拉跳轉列表,循環(huán)列出所有頁碼:

$pagenav .= " 到第 select name='topage' size='1' onchange='window.location=\"$url=\"+this.value'\n";

for ($i = 1; $i = $lastpg; $i++) {

if ($i == $page)

$pagenav .= "option value='$i' selected$i/option\n";

else

$pagenav .= "option value='$i'$i/option\n";

}

$pagenav .= "/select 頁,共 $lastpg 頁";

}

include("conn.php");

$result=mysql_query("SELECT * FROM `test`");

$total=mysql_num_rows($result);

//調用pageft(),每頁顯示10條信息(使用默認的20時,可以省略此參數(shù)),使用本頁URL(默認,所以省略掉).

_PAGEFT($total,5);

echo $pagenav;

$result=mysql_query("SELECT * FROM `test` limit $firstcount,$displaypg ");

while($row=mysql_fetch_array($result)){

echo "hrb".$row[name]." | ".$row[sex];

}

?

調用數(shù)據(jù)和分頁list.php

?php

/**

* 愛微網(wǎng)

*/

include("conn.php");

$pagesize=5;

$url=$_SERVER["REQUEST_URI"];

$url=parse_url($url);

$url=$url[path];

$numq=mysql_query("SELECT * FROM `test`");

$num = mysql_num_rows($numq);

if($_GET[page]){

$pageval=$_GET[page];

$page=($pageval-1)*$pagesize;

$page.=',';

}

if($num $pagesize){

if($pageval=1)$pageval=1;

echo "共 $num 條".

" a href=$url?page=".($pageval-1)."上一頁/a a href=$url?page=".($pageval+1)."下一頁/a";

}

echo $SQL="SELECT * FROM `test` limit $page $pagesize ";

$query=mysql_query($SQL);

while($row=mysql_fetch_array($query)){

echo "hrb".$row[name]." | ".$row[sex];

}

?

注意事項

注意分頁公式寫法你只要記住即可;

(當前頁數(shù) - 1 )X 每頁條數(shù) , 每頁條數(shù);

Select * from table limit ($Page- 1) * $PageSize, $PageSize;

注意三個代碼文件在同一個目錄下;

主要是最后的list.php調用代碼要細看很有用。

求PHP各種分頁方法,各位大仙有的別藏了~~

PHP分頁方法:

第一步創(chuàng)建一個類 subPages.php?php

class SubPages{

private $each_disNums;//每頁顯示的條目數(shù)

private $nums;//總條目數(shù)

private $current_page;//當前被選中的頁

private $sub_pages;//每次顯示的頁數(shù)

private $pageNums;//總頁數(shù)

private $page_array = array();//用來構造分頁的數(shù)組

private $subPage_link;//每個分頁的鏈接

private $subPage_type;//顯示分頁的類型

//__construct是SubPages的構造函數(shù),用來在創(chuàng)建類的時候自動運行. //@$each_disNums 每頁顯示的條目數(shù) // @nums 總條目數(shù) // @current_num 當前被選中的頁 //@sub_pages 每次顯示的頁數(shù) // @subPage_link 每個分頁的鏈接 //@subPage_type 顯示分頁的類型 //當@subPage_type=1的時候為普通分頁模式 example: 共4523條記錄,每頁顯示10條,當前第1/453頁 [首頁] [上頁] [下頁] [尾頁] //當@subPage_type=2的時候為經(jīng)典分頁樣式 example: 當前第1/453頁 [首頁] [上頁] 1 2 3 4 5 6 7 8 9 10 [下頁] [尾頁]

function __construct($each_disNums,$nums,$current_page,$sub_pages,$subPage_link,$subPage_type){

//intval通過使用特定的進制轉換(默認是十進制),返回變量 var 的 integer 數(shù)值

$this-each_disNums=intval($each_disNums);

$this-nums=intval($nums);

if(!$current_page){

$this-current_page=1;

}else{

$this-current_page=intval($current_page);

}

$this-sub_pages=intval($sub_pages);

$this-pageNums=ceil($nums/$each_disNums);

$this-subPage_link=$subPage_link;

$this-show_SubPages($subPage_type);

//echo $this-pageNums."--".$this-sub_pages;

}

//__destruct析構函數(shù),當類不在使用的時候調用,該函數(shù)用來釋放資源

function __destruct(){

unset($each_disNums);

unset($nums);

unset($current_page);

unset($sub_pages);

unset($pageNums);

unset($page_array);

unset($subPage_link);

unset($subPage_type);

}

//show_SubPages函數(shù)用在構造函數(shù)里面。而且用來判斷顯示什么樣子的分頁

function show_SubPages($subPage_type){

if($subPage_type == 1){

$this-subPageCss1();

}elseif ($subPage_type == 2){

$this-subPageCss2();

}

}

//用來給建立分頁的數(shù)組初始化的函數(shù)。

function initArray(){

for($i=0;$i$this-sub_pages;$i++){

$this-page_array[$i]=$i;

}

return $this-page_array;

}

//construct_num_Page該函數(shù)使用來構造顯示的條目

// 即使:[1][2][3][4][5][6][7][8][9][10]

function construct_num_Page(){

if($this-pageNums $this-sub_pages){

$current_array=array();

for($i=0;$i$this-pageNums;$i++){

$current_array[$i]=$i+1;

}

}else{

$current_array=$this-initArray();

if($this-current_page = 3){

for($i=0;$icount($current_array);$i++){

$current_array[$i]=$i+1;

}

}elseif ($this-current_page = $this-pageNums $this-current_page $this-pageNums - $this-sub_pages +1 ){

for($i=0;$icount($current_array);$i++){

$current_array[$i]=($this-pageNums)-($this-sub_pages)+1+$i;

}

}else{

for($i=0;$icount($current_array);$i++){

$current_array[$i]=$this-current_page-2+$i;

}

}

}

return $current_array;

}

//構造普通模式的分頁

//共4523條記錄,每頁顯示10條,當前第1/453頁 [首頁] [上頁] [下頁] [尾頁]

function subPageCss1(){

$subPageCss1Str="";

$subPageCss1Str.="共".$this-nums."條記錄,";

$subPageCss1Str.="每頁顯示".$this-each_disNums."條,";

$subPageCss1Str.="當前第".$this-current_page."/".$this-pageNums."頁 ";

if($this-current_page 1){

$firstPageUrl=$this-subPage_link."1";

$prewPageUrl=$this-subPage_link.($this-current_page-1);

$subPageCss1Str.="[a href='$firstPageUrl'首頁/a] ";

$subPageCss1Str.="[a href='$prewPageUrl'上一頁/a] ";

}else {

$subPageCss1Str.="[首頁] ";

$subPageCss1Str.="[上一頁] ";

}

if($this-current_page $this-pageNums){

$lastPageUrl=$this-subPage_link.$this-pageNums;

$nextPageUrl=$this-subPage_link.($this-current_page+1);

$subPageCss1Str.=" [a href='$nextPageUrl'下一頁/a] ";

$subPageCss1Str.="[a href='$lastPageUrl'尾頁/a] ";

}else {

$subPageCss1Str.="[下一頁] ";

$subPageCss1Str.="[尾頁] ";

}

echo $subPageCss1Str;

}

//構造經(jīng)典模式的分頁

//當前第1/453頁 [首頁] [上頁] 1 2 3 4 5 6 7 8 9 10 [下頁] [尾頁]

function subPageCss2(){

$subPageCss2Str="";

$subPageCss2Str.="當前第".$this-current_page."/".$this-pageNums."頁 ";

if($this-current_page 1){

$firstPageUrl=$this-subPage_link."1";

$prewPageUrl=$this-subPage_link.($this-current_page-1);

$subPageCss2Str.="[a href='$firstPageUrl'首頁/a] ";

$subPageCss2Str.="[a href='$prewPageUrl'上一頁/a] ";

}else {

$subPageCss2Str.="[首頁] ";

$subPageCss2Str.="[上一頁] ";

}

$a=$this-construct_num_Page();

for($i=0;$icount($a);$i++){

$s=$a[$i];

if($s == $this-current_page ){

$subPageCss2Str.="[span style='color:red;font-weight:bold;'".$s."/span]";

}else{

$url=$this-subPage_link.$s;

$subPageCss2Str.="[a href='$url'".$s."/a]";

}

}

if($this-current_page $this-pageNums){

$lastPageUrl=$this-subPage_link.$this-pageNums;

$nextPageUrl=$this-subPage_link.($this-current_page+1);

$subPageCss2Str.=" [a href='$nextPageUrl'下一頁/a] ";

$subPageCss2Str.="[a href='$lastPageUrl'尾頁/a] ";

}else {

$subPageCss2Str.="[下一頁] ";

$subPageCss2Str.="[尾頁] ";

}

echo $subPageCss2Str;

}

}

?要做分頁的頁面?php//每頁顯示的條數(shù)

$page_size=2;

//得到當前是第幾頁

$pageCurrent=$_GET["p"];

$offet =($pageCurrent-1)*$page_size;

//建立數(shù)據(jù)庫連接

$conn = mysql_connect("地址","用戶名","密碼") or die("".mysql_error());

//設置字符集

mysql_query("set names gbk");

//設置數(shù)據(jù)庫

mysql_select_db("數(shù)據(jù)庫名",$conn) or die("".mysql_error());

if($conn) { include ("query.html");

//查詢會員信息//注:這里的sql查詢了兩遍.第一遍是確定查詢出來的總數(shù)據(jù)條數(shù)

$query_sql = "SELECT * FROM user_info_t order by id desc";//第二遍是根據(jù)需要即$page_size來確定每次查出的條數(shù)

$query_sql_sec= "SELECT * FROM user_info_t order by id desc limit $offet,$page_size";

//執(zhí)行查詢語句 返回一個結果集

$query_res = mysql_query($query_sql,$conn);

$query_res_sec = mysql_query($query_sql_sec,$conn);

//查詢列數(shù)

//$query_cols = mysql_num_fields($query_res);

//查詢行數(shù)

$query_num =mysql_num_rows($query_res);

//返回根據(jù)從結果集取得的行生成的數(shù)組,如果沒有更多行

echo "table border='0' cellpadding='1' cellspacing='2' width='100%' bgcolor='#FFFFFF'";

while($query_row = mysql_fetch_array($query_res_sec)) {

echo "tr";

for ($i=0;$i$query_cols;$i++) {

echo "td bordercolor='#A2BEE1' bgcolor='#A2BEE1' width='8%'".$query_row[$i]."/td\n";

}

echo "td bordercolor='#A2BEE1' bgcolor='#A2BEE1' width='8%'";

//echo "input type='button' class='button' id='modify_record' name='modify_record' value='修改' /";

echo"button onClick=\"submit(location.href='../modify/modify.php?rec_id=$query_row[0]');\"class=\"button\";修改/button";

//echo "ahref='../delete/delete.php?rec_id=$query_row[0]'onClick=\"if(confirm('確實要刪除此條記錄嗎?')) return true;else returnfalse;\"img src=\"../image/delete.gif\" align=\"absmiddle\"/刪除/a";

echo "buttononClick=\"if(confirm('確實要刪除此條記錄嗎?')) return submit(location.href='../delete/delete.php?rec_id=$query_row[0]');else return false;\"class=\"button\";刪除/button";

echo "/td";

echo "/tr";

}

//echo "/form";

echo "/table";

require_once("../common/subPages.php");//總條目數(shù)為數(shù)據(jù)庫中查詢出的數(shù)據(jù)條數(shù)

$nums=$query_num;

//每次顯示的頁數(shù)

$sub_pages=10; //if(!$pageCurrent) $pageCurrent=1;

//調用類SubPages 傳的參數(shù)為:每頁顯示條數(shù)/當前第幾頁/每次顯示的頁數(shù)/分頁模式

$subPage=new SubPages($page_size,$nums,$pageCurrent,$sub_pages,"query.php?p=",1);

}else{

die('數(shù)據(jù)庫連接異常: '.mysql_error());

}

//斷開數(shù)據(jù)庫連接

if ($conn)

{

mysql_close($conn);

}

?

這個簡單的PHP分頁類,該如何調用?感謝。~

0代表開始的下標,比如一頁顯示10條的話,那么第一頁就是0,10,第二頁就是(2-1)*10,10,第三頁就是(3-1)*10,10

所以你那個0 就是寫 limit($page-1)*$pagenum,$pagenum

PHP顯示很多數(shù)據(jù)庫信息,如何自動分頁呢?代碼

這是我以前學php寫的 哈哈 你可以看看

?php

/**

* 分頁類

* 1.實例化分頁類,例:mypage new page("SQL語句","每頁顯示記錄條數(shù)");

* 2.調用類中的 genpage() 方法,返回分頁生成的SQL語句;

* 3.執(zhí)行新生成的SQL語句;

* 4.調用 showpage_1() 或 showpage_2() 方法顯示分頁的翻頁(可也以自定義返回顯示的方式)

* 實例:

* $page = new page("select * from ly",2);

* $sql=$page-genpage();

* $ar=mysql_query($sql);

* while($nu=mysql_fetch_array($ar)){

* echo $nu[0].'br';

* }

* $page-showpage_2();

*/

class page{

private $totalnum; //總記錄數(shù)

private $pagecount; //總頁數(shù)

private $f_pagenum; //當前頁的第一條記錄

private $sql;

private $page; //當前頁

private $page_size; //每頁顯示數(shù)量

private $pagesql;

private $total;

private $url; //當前頁url

private $beforepage; //上一頁

private $nextpage; //下一頁

function __construct($sql,$page_size){ //傳入sql語句和每頁顯示條數(shù)

$this-sql=$sql;

$this-page_size=$page_size;

$this-page=is_numeric($_GET[page]);

$this-page=substr($this-page,0,10);

$this-page=mysql_real_escape_string($this-page);

if(ereg("^[0-9]*[1-9][0-9]*$",$this-page)!=1){

$this-page=1;

}

if($this-page99999999){

$this-page=1;

}

}

function genpage(){

//

// if(!$this-page){

// $this-page=1;

// }

$this-pagesql = strstr($this-sqlcz," from ");

$this-pagesql = "select count(*) as ids ".$this-pagesql;

$this-total=mysql_query($this-sql);

$this-totalnum=mysql_num_rows($this-total); //總記錄數(shù)

$this-pagecount=ceil($this-totalnum/$this-page_size); //總頁數(shù)

$this-f_pagenum=$this-page_size*($this-page-1); //當前頁的第一條記錄

$this-sql .=" limit $this-f_pagenum,$this-page_size ";

return $this-sql;

}

//替換url中的page的頁數(shù)

function replace_page($npage){

$this-url=$_SERVER["REQUEST_URI"]; //獲取當前url

$check = strpos($this-url, 'page='); //判斷url中是否有page分頁參數(shù)

if($check==false){ //如果沒有page分頁參數(shù)

if(strpos($this-url, '?')==false){ //判斷是否url是否有“ ?”號,

$this-url=$this-url."?page=1"; //如果沒有“ ?”號,說明之前url沒有參數(shù)

}else{

$this-url=$this-url."page=1"; //如果有“ ?”號,說明有參數(shù),追加參數(shù)要改用符號

}

}

$npage="page=".$npage; //跳轉到的頁

$zz='[page=\d*]';

return preg_replace($zz,$npage,$this-url); //正則替換掉url中的page參數(shù),實現(xiàn)分頁

}

//顯示總頁數(shù)

function show_all_page(){

return $this-pagecount;

}

//顯示當前頁

function show_current_page(){

return $this-page;

}

//顯示首頁和上一頁

function show_firstAndup_page(){

if($this-page==1){

return "首頁|上一頁";

}else{

$this-beforepage=$this-page-1;

return "a href=".$this-replace_page(1)."首頁/a|a href=".$this-replace_page($this-beforepage)."上一頁/a";

}

}

//顯示下一頁和最后頁

function show_lastAnddown_page(){

if(($this-page==$this-pagecount)||($this-pagecount==0)){

return "下一頁|尾頁";

}else{

$this-nextpage=$this-page+1;

return "a href=".$this-replace_page($this-nextpage)."下一頁/a|a href=".$this-replace_page($this-pagecount)."尾頁/a";

}

}

//循環(huán)顯示頁數(shù)

function show_loop_page(){

$shownum =10/2;

$startpage = ($this-page$shownum)?$this-page-$shownum:1;

$endpage = ($this-page+$shownum=$this-pagecount)?$this-page+$shownum:$this-pagecount;

for($i=$startpage;$i=$endpage;$i++)

{

if($i==$this-page) {

$a= " b[".($i)."]/b ";

}else{

$a= " a href=".$this-replace_page($i)."".($i)."/a ";

}

$b=$b.$a;

}

return $b;

}

//整體顯示第一種方案

function showpage_1(){

return "共".$this-show_all_page()."頁nbsp"."當前第".$this-show_current_page()."頁nbsp".$this-show_firstAndup_page()."nbsp"

.$this-show_loop_page()."nbsp".$this-show_lastAnddown_page();

}

//整體顯示第二種方案

function showpage_2(){

return $this-show_firstAndup_page()."nbsp".$this-show_loop_page()."nbsp".$this-show_lastAnddown_page();

}

}

?

當前名稱:漂亮的php數(shù)據(jù)分頁類 php分頁函數(shù)封裝
地址分享:http://muchs.cn/article46/doscjeg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設、定制網(wǎng)站、外貿網(wǎng)站建設、網(wǎng)站制作、企業(yè)建站、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設計公司