php数据分页技术的实现,在php中如何对多条记录进行分页

php实现分页功能

具体代码如下:

创新互联建站成立于2013年,是专业互联网技术服务公司,拥有项目成都做网站、成都网站设计、成都外贸网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元稷山做网站,已为上家服务,为稷山各地企业和个人服务,联系电话:18982081108

/**

* 获取分页的HTML内容

* @param integer $page 当前页

* @param integer $pages 总页数

* @param string $url 跳转url地址 最后的页数以 'page=x' 追加在url后面

*

* @return string HTML内容;

*/

public static function getPageHtml($page, $pages, $url){

//最多显示多少个页码

$_pageNum = 5;

//当前页面小于1 则为1

$page = $page1?1:$page;

//当前页大于总页数 则为总页数

$page = $page $pages ? $pages : $page;

//页数小当前页 则为当前页

$pages = $pages $page ? $page : $pages;

//计算开始页

$_start = $page - floor($_pageNum/2);

$_start = $_start1 ? 1 : $_start;

//计算结束页

$_end = $page + floor($_pageNum/2);

$_end = $_end$pages? $pages : $_end;

//当前显示的页码个数不够最大页码数,在进行左右调整

$_curPageNum = $_end-$_start+1;

//左调整

if($_curPageNum$_pageNum $_start1){

$_start = $_start - ($_pageNum-$_curPageNum);

$_start = $_start1 ? 1 : $_start;

$_curPageNum = $_end-$_start+1;

}

//右边调整

if($_curPageNum$_pageNum $_end$pages){

$_end = $_end + ($_pageNum-$_curPageNum);

$_end = $_end$pages? $pages : $_end;

}

$_pageHtml = 'ul class="pagination"';

/*if($_start == 1){

$_pageHtml .= 'lia title="第一页"«/a/li';

}else{

$_pageHtml .= 'lia title="第一页" href="'.$url.'page=1"«/a/li';

}*/

if($page1){

$_pageHtml .= 'lia title="上一页" href="'.$url.'page='.($page-1).'"«/a/li';

}

for ($i = $_start; $i = $_end; $i++) {

if($i == $page){

$_pageHtml .= 'li class="active"a'.$i.'/a/li';

}else{

$_pageHtml .= 'lia href="'.$url.'page='.$i.'"'.$i.'/a/li';

}

}

/*if($_end == $pages){

$_pageHtml .= 'lia title="最后一页"»/a/li';

}else{

$_pageHtml .= 'lia title="最后一页" href="'.$url.'page='.$pages.'"»/a/li';

}*/

if($page$_end){

$_pageHtml .= 'lia title="下一页" href="'.$url.'page='.($page+1).'"»/a/li';

}

$_pageHtml .= '/ul';

echo $_pageHtml;

}

Thinkphp数组分页如何操作

第一种:利用Page类和limit方法

$User = M('User'); // 实例化User对象

import('ORG.Util.Page');// 导入分页类

$count = $User-where('status=1')-count();// 查询满足要求的总记录数

$Page = new Page($count,25);// 实例化分页类 传入总记录数和每页显示的记录数

$show = $Page-show();// 分页显示输出

// 进行分页数据查询 注意limit方法的参数要使用Page类的属性

$list = $User-where('status=1')-order('create_time')-limit($Page-firstRow.','.$Page-listRows)-select();

$this-assign('list',$list);// 赋值数据集

$this-assign('page',$show);// 赋值分页输出

$this-display(); // 输出模板

第二种:分页类和page方法的实现

$User = M('User'); // 实例化User对象

// 进行分页数据查询 注意page方法的参数的前面部分是当前的页数使用 $_GET[p]获取

$list = $User-where('status=1')-order('create_time')-page($_GET['p'].',25')-select();

$this-assign('list',$list);// 赋值数据集

import(“ORG.Util.Page”);// 导入分页类

$count = $User-where('status=1')-count();// 查询满足要求的总记录数

$Page = new Page($count,25);// 实例化分页类 传入总记录数和每页显示的记录数

$show = $Page-show();// 分页显示输出

$this-assign('page',$show);// 赋值分页输出

$this-display(); // 输出模板

带入查询条件

如果是POST方式查询,如何确保分页之后能够保持原先的查询条件呢,我们可以给分页类传入参数,方法是给分页类的parameter属性赋值:

import('ORG.Util.Page');// 导入分页类

$mapcount = $User-where($map)-count();// 查询满足要求的总记录数

$Page = new Page($count,25);// 实例化分页类 传入总记录数和每页显示的记录数

//分页跳转的时候保证查询条件

foreach($map as $key=$val) {

$Page-parameter .= "$key=".urlencode($val).'';

}

$show = $Page-show();// 分页显示输出

thinkphp一个页面需要多个分页怎么实现

使用ajax分页 多个分页数据分开多个ajax请求去请求数据分页函数也可以分开使用

如果你是用的是tp自带的分页做那么你可以改下参数 比如第一个分页参数为page=xxx第二个就使用page2=xxx 以此类推

php怎么实现无刷新分页效果

php+ajax实现无刷新分页实现方法具体如下:

limit 偏移量,长度;

limit 0,7; 第一页

limit 7,7; 第二页

limit 14,7; 第三页

每页信息条数:7

信息总条数:select count(*) from table

信息总页数:ceil向上取整(总条数/每页条数)

1、分页类具体使用

?php

class Pagination {

private $total; //数据表中总记录数

private $listRows; //每页显示行数

private $limit; //mysql 数据库的limit

private $uri; //分页信息前面的uri地址

private $pageNum; //页数

private $config = array('header' = "个记录", "prev" = "【上一页】", "next" = "【下一页】", "first" = "【首 页】", "last" = "【尾 页】");

private $listNum = 8;

/*

* $total 当前信息总条数

* $listRows 每页显示的条数

* $pa 下面的page

http://网址/index.php?page=5

*/

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;//不传入page,则默认显示首页

$this-pageNum = ceil($this-total / $this-listRows);

$this-limit = $this-setLimit();

}

//设置每页显示的条数

private function setLimit() {

return "Limit " . ($this-page - 1) * $this-listRows . ", {$this-listRows}";

}

//获得URL地址

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;

}

//魔术方法,

public 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() {

$html = "";

if ($this-page == 1)

$html.=' '.$this-config["first"].' ';

else

$html.=" a href='javascript:void(0)' onclick='showPage(\"{$this-uri}page=1\")'{$this-config["first"]}/a ";

//$html.=" a href='{$this-uri}page=1'{$this-config["first"]}/a ";

return $html;

}

/*设置上一页*/

private function prev() {

$html = "";

if ($this-page == 1)

$html.=' '.$this-config["prev"].' ';

else

$html.=" a href='javascript:void(0)' onclick='showPage(\"{$this-uri}page=" . ($this-page - 1) . "\")'{$this-config["prev"]}/a ";

//$html.=" a href='{$this-uri}page=".($this-page-1)."'{$this-config["prev"]}/a ";

return $html;

}

//页码列表【首页】【2】【3】…………【尾页】

private function pageList() {

$linkPage = "";

$inum = floor($this-listNum / 2);

for ($i = $inum; $i = 1; $i--) {

$page = $this-page - $i;

if ($page 1)

continue;

$linkPage.=" a href='javascript:void(0)' onclick='showPage(\"{$this-uri}page={$page}\")'{$page}/a ";

}

$linkPage.=" {$this-page} ";

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

$page = $this-page + $i;

if ($page = $this-pageNum)

$linkPage.=" a href='javascript:void(0)' onclick='showPage(\"{$this-uri}page={$page}\")'{$page}/a ";

else

break;

}

return $linkPage;

}

/*设置下一页*/

private function next() {

$html = "";

if ($this-page == $this-pageNum)

$html.=' '.$this-config["next"].' ';

else

$html.=" a href='javascript:void(0)' onclick='showPage(\"{$this-uri}page=" . ($this-page + 1) . "\")'{$this-config["next"]}/a ";

//$html.=" a href='{$this-uri}page=".($this-page + 1)."'{$this-config["next"]}/a ";

return $html;

}

/*设置尾页*/

private function last() {

$html = "";

if ($this-page == $this-pageNum)

$html.=' '.$this-config["last"].' ';

else

$html.=" a href='javascript:void(0)' onclick='showPage(\"{$this-uri}page=" . ($this-pageNum) . "\")'{$this-config["last"]}/a ";

//$html.=" a href='{$this-uri}page=.(this-pageNum).'{$this-config["last"]}/a ";

return $html;

}

/*设置页面跳转*/

private function goPage() {

return

' input type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value' . $this-pageNum . ')?' . $this-pageNum . ':this.value;showPage(\'' . $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;showPage(\'' . $this-uri . 'page=\'+page+\'\')" ';

}

//页面列表配置选项

function fpage($display = array(0, 1, 2, 3, 4, 5, 6, 7, 8)) {

$html[0] = " 共有b{$this-total}/b{$this-config["header"]} ";

$html[1] = " 每页显示b" . ($this-end() - $this-start() + 1) . "/b条,本页b{$this-start()}-{$this-end()}/b条 ";

$html[2] = " b{$this-page}/{$this-pageNum}/b页 ";

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

}

}

2 数据显示

?php

//链接数据库

//获得具体信息

//分页显示

header("content-type:text/html;charset=utf-8");

$link = mysql_connect('localhost','root','111111');

mysql_select_db('shop', $link);

mysql_query("set names utf8");

$css = eof

style type="text/css"

table {border:1px solid black; width:700px; margin:auto; border-collapse:collapse;}

td {border:1px solid black; }

/style

eof;

echo $css;

echo "

table

trtd序号/tdtd名称/tdtd数量/tdtd价格/tdtd时间/td/tr

";

//1 引入分页类

include "./Pagination.php";

//2. 获得信息总条数

$sql = "select * from sw_goods";

$qry = mysql_query($sql);

$total = mysql_num_rows($qry);

$per = 7;

//3. 实例化分页类对象

$page_obj = new Pagination($total,$per);

//4. 拼装sql语句,获得每页信息

//利用page_obj实现limit的灵活设置

//$page_obj - limit;

$sqla = "select * from sw_goods ".$page_obj-limit;

$qrya = mysql_query($sqla);

//5. 获得页面列表

$pagelist = $page_obj - fpage(array(3,4,5,6,7,8));

$i=1;

while($rsta = mysql_fetch_assoc($qrya)){

echo "tr";

echo "td".$i++."/td";

echo "td".$rsta['goods_name']."/td";

echo "td".$rsta['goods_number']."/td";

echo "td".$rsta['goods_price']."/td";

echo "td".date("Y-m-d H:i:s",$rsta['goods_create_time'])."/td";

echo "/tr";

}

echo "trtd colspan=5".$pagelist."/td/tr";

echo "/table";

3 ajax无刷新分页实现

open(‘get','http://网址/index.php?page=2')

!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" ""

html

head

title新建网页/title

meta http-equiv="Content-Type" content="text/html; charset=utf-8" /

meta name="description" content="" /

meta name="keywords" content="" /

script type="text/javascript"

//获得分页信息ajax函数

function showPage(myurl){

var xhr = new XMLHttpRequest();

xhr.onreadystatechange = function(){

if(xhr.readyState==4){

var rst = document.getElementById("result");

rst.innerHTML = xhr.responseText;

}

}

xhr.open("get",myurl);

xhr.send(null);

}

window.onload = function(){

showPage("./data1.php"); //获得分页信息

//showPage("./data.php?page=2");

}

/script

style type="text/css"

/style

/head

body

h2ajax无刷新分页效果/h2

div id="result"/div

/body

/html

script type="text/javascript"

document.write(new Date()+"br /");

document.write(new Date()+"br /");

document.write(new Date()+"br /");

document.write(new Date()+"br /");

/script

用PHP如何实现分页并能够实现上一页,下一页,跳转到()页的功能?

htmlhead

title分页示例(php/title

meta http-equiv="Content-Type" content="text/html; charset=gb2312"

/head

body

?php

$pagesize=10; //设定每一页显示的记录数

$conn=mysql_connect("localhost","root","jrq");

mysql_select_db("sj",$conn);

$rs = mysql_query( "select * from `dw_newsdata`",$conn); //这里有第二个可选参数,指定打开的连接

//-----------------------------------------------------------------------------------------------//

//分页逻辑处理

//-----------------------------------------------------------------------------------------------

$tmpArr = mysql_fetch_array($rs);

$numAL = mysql_num_rows($rs); //取得记录总数$rs

$pages=intval($numAL/$pagesize); //计算总页数

if ($numAL % $pagesize) $pages++;

//设置缺省页码

//↓判断“当前页码”是否赋值过

if (isset($_GET['page'])){ $page=intval($_GET['page']); }else{ $page=1; }//否则,设置为第一页

//↓计算记录偏移量

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

//↓读取指定记录数

$rs=mysql_query("select * from `dw_newsdata` limit $offset,$pagesize",$conn);//取得—当前页—记录集!

$curNum = mysql_num_rows($rs); //$curNum - 当前页实际记录数,for循环输出用

?

table border="0" width="80%"

tr

td width="50%" bgcolor="#E0E0E0"标题/td

td width="50%" bgcolor="#E0E0E0"发布时间/td

/tr

?php

while ($tmpArr = mysql_fetch_array($rs)) //提取一行,并循环判断

{

$i=0;

// for($a=0;$a$ColNum;$a++) //==for结束==

?

tr

td width="50%"?= $tmpArr[1]; //$tmpArr["news_title"] ; ?/td

td width="50%"?php echo $tmpArr[2]; //$tmpArr["news_cont"]; ?/td

/tr

?php

}//==while结束==

?

/table

?php

//============================//

// 翻页显示 一

//============================//

echo "p"; // align=center

$first=1;

$prev=$page-1;

$next=$page+1;

$last=$pages;

if ($page 1)

{

echo "a href='?page=".$first."'首页/a ";

echo "a href='?page=".$prev."'上一页/a ";

}

if ($page $pages)

{

echo "a href='?page=".$next."'下一页/a ";

echo "a href='?page=".$last."'尾页/a ";

}

//============================//

// 翻页显示 二

//============================//

echo " | 共有".$pages."页(".$page."/".$pages.")";

for ($i=1;$i $page;$i++){echo "a href='?page=".$i."'[".$i ."]/a ";} // 1-先输出当前页之前的

if ($page 0) echo "[".$page."]";; // 2-再输出当前页

for ($i=$page+1;$i=$pages;$i++){echo "a href='?page=".$i."'[".$i ."]/a ";}// 3-接着输出当前页之后

echo "转到第 INPUT maxLength=3 size=3 value=".($page+1)." name=gotox 页 INPUT hideFocus onclick=\"location.href='?page=gotox.value';\" type=button value=Go name=cmd_goto";

echo "/p";

?

/body

/html

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数据分页技术的实现,在php中如何对多条记录进行分页
网站URL:https://www.cdcxhl.com/article4/hedhie.html

成都网站建设公司_创新互联,为您提供网站内链网站导航电子商务网站设计公司动态网站网站收录

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

小程序开发