您的位置:

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框架,然后打开里面的分页类查看里面的源代码。