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/n/128055.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
T3B2IT3B2I
上一篇 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

发表回复

登录后才能评论