php分頁,php分頁列表展示

本文目錄一覽:

PHP怎麼製作分頁

方法/步驟

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

SELECT * FROM table …… limit 開始位置 , 操作條數

開始位置從0開始

SELECT * FROM table …… limit 0 , 20

取最前面20條

SELECT * FROM table …… limit 10 , 20

11條到20條

其次分頁要用的公式

得到公式

(當前頁數 – 1 )X 每頁條數 , 每頁條數

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

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

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

$ua=parse_url(“”);

print_r($ua);

結果:

Array

(

[scheme] = http

[host] = hostname

[user] = username

[pass] = password

[path] = /path

[query] = arg=value

[fragment] = anchor

)

創建資料庫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 ;

然後插入十幾條測試數據即可

寫mysql資料庫連接代碼保存conn.php文件里

代碼如下

?php

$conn = @ mysql_connect(“localhost”, “root”, “”) or die(“資料庫鏈接錯誤”);

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();

?

寫分頁函數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); //最後頁,也是總頁數

$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 條記錄”;

//如果只有一頁則跳出函數:

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 “;

//下拉跳轉列表,循環列出所有頁碼:

$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時,可以省略此參數),使用本頁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];

}

?

調用數據和分頁list.php

?php

/**

* 愛微網

*/

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];

}

?

注意事項

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

(當前頁數 – 1 )X 每頁條數 , 每頁條數;

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

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

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

php分頁代碼

?phpbr

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

?

上一頁

顯示上一頁

?phpbr

}

for

($i=1;$i=$totalPage;$i++)

{

//循環顯示出頁面

?

?php

echo

$i

;?

?phpbr

}

if

($page$totalPage)

{

//如果page小於總頁數,顯示下一頁鏈接

?

下一頁

?phpbr

}

?

================================

這個是很簡單的..而且也寫了注釋..不知道合不合你的意..

PHP分頁問題,如何分頁。

?php

class page

{

private $pagesize;

private $lastpage;

private $totalpages;

private $nums;

private $numPage=1;

function __construct($page_size,$total_nums)

{

$this-pagesize=$page_size; //每頁顯示的數據條數

$this-nums=$total_nums; //總的數據條數

$this-lastpage=ceil($this-nums/$this-pagesize); //最後一頁

$this-totalpages=ceil($this-nums/$this-pagesize); //總得分頁數

if(!empty($_GET[page]))

{

$this-numPage=$_GET[page];

if(!is_int($this-numPage)) $this-numPage=(int)$this-numPage;

if($this-numPage1) $this-numPage=1;

if($this-numPage$this-lastpage) $this-numPage=$this-lastpage;

}

}

function show_page_result()

{

$row_num=(($this-numPage)-1) * $this-pagesize; //表示每一頁從第幾條數據開始顯示

$row_num=$row_num.”,”;

$SQL=”SELECT * FROM `test` LIMIT $row_num $this-pagesize”;

$db=new database();

$query=$db-execute($SQL);

while($row=mysql_fetch_array($query))

{

echo “b”.$row[name].” | “.$row[sex].”hr”;

}

$db=null;

}

function show_page_way_1() //以”首頁 上一頁 下一頁 尾頁”形式顯示

{

$url=$_SERVER[“REQUEST_URI”];

$url=parse_url($url); //parse_url — 解析 URL,返回其組成部分,注: 此函數對相對路徑的 URL 不起作用。

$url=$url[path];

if($this-nums $this-pagesize) //判斷是否滿足分頁條件

{

echo ” 共 $this-totalpages 頁 當前為第font color=redb$this-numPage/b/font頁 共 $this-nums 條 每頁顯示 $this-pagesize 條”;

if($this-numPage==1)

{

echo ” 首頁 “;

echo “上一頁 “;

}

if($this-numPage = 2 $this-numPage = $this-lastpage)

{

echo ” a href=$url?page=1首頁/a ” ;

echo “a href=$url?page=”.($this-numPage-1).”上一頁/a ” ;

}

if($this-numPage==$this-lastpage)

{

echo “下一頁 “;

echo “尾頁br”;

}

if($this-numPage = 1 $this-numPage $this-lastpage)

{

echo “a href=$url?page=”.($this-numPage+1).”下一頁/a “;

echo “a href=$url?page=$this-lastpage尾頁/abr “;

}

}

else return;

}

function show_page_way_2() //以數字形式顯示”首頁 1 2 3 4 尾頁”

{

$url=$_SERVER[“REQUEST_URI”];

$url=parse_url($url); //parse_url — 解析 URL,返回其組成部分,注: 此函數對相對路徑的 URL 不起作用。

$url=$url[path];

if($this-nums $this-pagesize)

{

if($this-numPage==1) echo “首頁”;

else echo “a href=$url?page=1首頁/a”;

for($i=1;$i=$this-totalpages;$i++)

{

if($this-numPage==$i)

{

echo ” “.$i.” “;

}

else

{

echo ” a href=$url?page=$i$i/a “;

}

}

if($this-numPage==$this-lastpage) echo “尾頁”;

else echo “a href=$url?page=$this-lastpage尾頁/a”;

}

}

function show_page_way_3()

{

global $c_id;

$url=$_SERVER[“REQUEST_URI”];

$url=parse_url($url); //parse_url — 解析 URL,返回其組成部分,注: 此函數對相對路徑的 URL 不起作用。

$url=$url[path];

if($this-nums $this-pagesize) //判斷是否滿足分頁條件

{

if($c_id)

{

echo “到第select name=’select1′ onChange=\”location.href=’$url?c_id=$c_idpage=’+this.value+’pagesize=$this-pagesize’\””;

}

else echo “到第select name=’select1′ onChange=\”location.href=’$url?page=’+this.value+’pagesize=$this-pagesize’\””;

for($i = 1;$i = $this-totalpages;$i++)

echo “option value='” . $i . “‘” . (($this-numPage == $i) ? ‘selected’ : ”) . “” . $i . “/option”;

echo “/select頁, 每頁顯示”;

if($c_id)

{

echo “select name=select2 onChange=\”location.href=’$url?c_id=$c_idpage=$this-numPagepagesize=’+this.value+”\””;

}

else echo “select name=select2 onChange=\”location.href=’$url?page=$this-numPagepagesize=’+this.value+”\””;

for($i = 0;$i 5;$i++) // 將個數定義為五種選擇

{

$choice= ($i+1)*4;

echo “option value='” . $choice . “‘” . (($this-pagesize == $choice) ? ‘selected’ : ”) . “” . $choice . “/option”;

}

echo “/select個”;

}

else return; //echo “沒有下頁了”;

}

}

?

php分頁功能怎麼實現

php本身是沒有分頁概念的,分頁是URL傳參,然後通過mysql查詢語句到資料庫獲取數據,然後實現的分頁,url上的參數,通過PHP的$_GET都是可以獲取到的。

現在市面上的PHP框架基本都有PHP分頁類,參照文檔直接調用就好了,如果想看實現過程,可以去下載一個TP框架,然後打開裡面的分頁類查看裡面的源代碼。

原創文章,作者:T3B2I,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/128055.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
T3B2I的頭像T3B2I
上一篇 2024-10-03 23:24
下一篇 2024-10-03 23:24

相關推薦

  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • Python字元轉列表指南

    Python是一個極為流行的腳本語言,在數據處理、數據分析、人工智慧等領域廣泛應用。在很多場景下需要將字元串轉換為列表,以便於操作和處理,本篇文章將從多個方面對Python字元轉列…

    編程 2025-04-29
  • Python中不同類型的列表

    Python是一種功能強大的編程語言,其內置數據結構之一為列表。列表可以容納任意數量的元素,並且可以存儲不同類型的數據。 一、列表的基本操作 Python的列表類型支持許多操作,如…

    編程 2025-04-29
  • Python為什麼輸出空列表

    空列表是Python編程中常見的數據類型,在某些情況下,會出現輸出空列表的情況。下面我們就從多個方面為大家詳細闡述為什麼Python會輸出空列表。 一、賦值錯誤 在Python中,…

    編程 2025-04-29
  • jQuery Datatable分頁中文

    jQuery Datatable是一個非常流行的數據表插件,它可以幫助您快速地在頁面上創建搜索、過濾、排序和分頁的數據表格。不過,它的默認設置是英文的,今天我們就來探討如何將jQu…

    編程 2025-04-29
  • PHP怎麼接幣

    想要在自己的網站或應用中接受比特幣等加密貨幣的支付,就需要對該加密貨幣擁有一定的了解,並使用對應的API進行開發。本文將從多個方面詳細闡述如何使用PHP接受加密貨幣的支付。 一、環…

    編程 2025-04-29
  • Python定義兩個列表的多面探索

    Python是一種強大的編程語言,開放源代碼,易於學習和使用。通過Python語言,我們可以定義各種數據類型,如列表(list)。在Python中,列表(list)在處理數據方面起…

    編程 2025-04-29
  • Python編程實現列表元素逆序存放

    本文將從以下幾個方面對Python編程實現列表元素逆序存放做詳細闡述: 一、實現思路 一般來說,使用Python將列表元素逆序存放可以通過以下幾個步驟實現: 1. 定義一個列表 2…

    編程 2025-04-29
  • Python列表的讀寫操作

    本文將針對Python列表的讀取與寫入操作進行詳細的闡述,包括列表的基本操作、列表的增刪改查、列表切片、列表排序、列表反轉、列表拼接、列表複製等操作。 一、列表的基本操作 列表是P…

    編程 2025-04-29
  • Python字典列表去重

    這篇文章將介紹如何使用Python對字典列表進行去重操作,並且從多個方面進行詳細的闡述。 一、基本操作 首先我們需要了解Python字典列表去重的基本操作。Python中提供了一種…

    編程 2025-04-28

發表回復

登錄後才能評論