好得很程序员自学网
  • 首页
  • 后端语言
    • C#
    • PHP
    • Python
    • java
    • Golang
    • ASP.NET
  • 前端开发
    • Angular
    • react框架
    • LayUi开发
    • javascript
    • HTML与HTML5
    • CSS与CSS3
    • jQuery
    • Bootstrap
    • NodeJS
    • Vue与小程序技术
    • Photoshop
  • 数据库技术
    • MSSQL
    • MYSQL
    • Redis
    • MongoDB
    • Oracle
    • PostgreSQL
    • Sqlite
    • 数据库基础
    • 数据库排错
  • CMS系统
    • HDHCMS
    • WordPress
    • Dedecms
    • PhpCms
    • 帝国CMS
    • ThinkPHP
    • Discuz
    • ZBlog
    • ECSHOP
  • 高手进阶
    • Android技术
    • 正则表达式
    • 数据结构与算法
  • 系统运维
    • Windows
    • apache
    • 服务器排错
    • 网站安全
    • nginx
    • linux系统
    • MacOS
  • 学习教程
    • 前端脚本教程
    • HTML与CSS 教程
    • 脚本语言教程
    • 数据库教程
    • 应用系统教程
  • 新技术
  • 编程导航
    • 区块链
    • IT资讯
    • 设计灵感
    • 建站资源
    • 开发团队
    • 程序社区
    • 图标图库
    • 图形动效
    • IDE环境
    • 在线工具
    • 调试测试
    • Node开发
    • 游戏框架
    • CSS库
    • Jquery插件
    • Js插件
    • Web框架
    • 移动端框架
    • 模块管理
    • 开发社区
    • 在线课堂
    • 框架类库
    • 项目托管
    • 云服务

当前位置:首页>后端语言>PHP
<tfoot draggable='sEl'></tfoot>

php分页选择页数 php分页函数封装

很多站长朋友们都不太清楚php分页选择页数,今天小编就来给大家整理php分页选择页数,希望对各位有所帮助,具体内容如下:

本文目录一览: 1、 php分页怎么弄? 2、 php应该怎样分页 3、 用php怎样完成数字分页 4、 php中怎么分页 php分页怎么弄?

/*

总数据条数    $total;

每页数据条数  $perpage;

当前页    $page;

总页数 $cnt = ceil($total/$perpage); ceil函数+1取整.

在$page页,说明前面已经过了($page-1)*$perpage条数据

从($page-1)*$perpage+1开始取数据

分页导航思路:

循环在当前页的前后加“<a href="">[]</a>”,使其效果为[2][3][4]5[6][7][8]

以下是分页导航类的代码

*/

class PageTool {

    protected $total = 0;

    protected $perpage = 6;

    protected $page = 1;

    public function __construct($total,$page=false,$perpage=false) {

        $this->total = $total;

        if($perpage) {

            $this->perpage = $perpage;

        }

        if($page) {

            $this->page = $page;

        }

    }

   // 创建分页导航

    public function show() {

        $cnt = ceil($this->total/$this->perpage);  // 得到总页数

        $uri = $_SERVER['REQUEST_URI'];

        $parse = parse_url($uri);

        $param = array();

        if(isset($parse['query'])) {

            parse_str($parse['query'],$param);

        }

       // 不管$param数组里,有没有page单元,都unset一下,确保没有page单元,

        // 即保存除page之外的所有单元

        unset($param['page']);

        $url = $parse['path'] . '?';

        if(!empty($param)) {

            $param = http_build_query($param);

            $url = $url . $param . '';

        }

       // 计算页码导航

        $nav = array();

        $nav[0] = '<span class="page_now">' . $this->page . '</span>';

        for($left = $this->page-1,$right=$this->page+1;($left>=1||$right<=$cnt)count($nav) <= 5;) {

            if($left >= 1) {

                array_unshift($nav,'<a href="' . $url . 'page=' . $left . '">[' . $left . ']</a>');

                $left -= 1;

            }

            if($right <= $cnt) {

                array_push($nav,'<a href="' . $url . 'page=' . $right . '">[' . $right . ']</a>');

                $right += 1;

            }

        }

        return implode('',$nav);

    }

}

//测试分页导航

$page = $_GET['page']?$_GET['page']:1;//  ?page=5

$p = new PageTool(100,$page,6); //数据总数100条,每页6条,当前第5页

echo $p->show();//效果为[2][3][4]5[6][7][8]

php应该怎样分页

我也和你一样,看了好多例子都不懂,后来看了这个,总算搞懂了。这个还算简单,是说的php mysql的分页。

正文:

在看本文之前,请确保你已掌握了PHP的一些知识以及MYSQL的查询操作基础哦。

作为一个Web程序,经常要和不计其数的数据打交道,比如会员的数据,文章数据,假如只有几十个会员那很好办,在一页显示就可以了,可是假如你的网站是几千甚至几十万会员的话,如果都在一页打开的话无论对浏览器还是观看者都是一种折磨。

相信每个学习PHP的新手都会对分页这个东西感觉很头疼,不过有了默默的这一水帖,你肯定会拍拍脑袋说,嘿,原来分页竟然如此简单?的确,现在请深呼吸一口新鲜的空气,仔细的听默默给你一点一点的分解。

假设我们要处理1000条数据,要在每页中显示10条,这样的话就会分100页来显示,咱们先看一看在mysql里提取10条信息是如何操作的。

Select * from table limit 0,10

上面是一句很简单的mysql查询语句,它的作用是从一个名叫table的表里提取10条数据,并且把所有字段的值都获得。

关键的地方就在这段“limit 0,10”,它其中的0是以0为起始点,后面的10则是显示10条数据,那么我们要以10为起始点,显示到第20条数据该怎么写呢?

可能很多大大会心直口快的说“limit 10,20”嘛!啊哦,这样可就错误了哦,正确的写法是“limit 10,10”它后面的参数并非是结束点而是要提取的数目,记住哦。

懂得了如何提取10条数据,那么提取1000条也就是做100次这种查询呀,就是说要做如下的查询:

Limit 0,10 //第一页

Limit 10,10 //第二页

Limit 20,10 //第三页

Limit 30,10 //第四页

……

看出有什么规律了吗?没错,第一个参数每翻一页就增加10,可是第二个参数是不变的。

也就是说咱们设法根据页数来改变第一个参数的值,就可以进行分页显示数据了,怎么样,原理是不是很简单?

可是要怎么设法根据页数来改变第一个参数的值呢?首先,咱们要有一个页数的值,用url的GET方式获取。

比如index.php?page=18

相信大部分的大大对这个东西不陌生吧,这种url地址可是随处可见,其中的page参数的作用就是传入要显示的页数。

咱们通过一段代码来看一看究竟是如何实现的吧:

PHP代码如下:

/*

Author:默默

Date :2006-12-03

*/

$page=isset($_GET['page'])?intval($_GET['page']):1; //这句就是获取page=18中的page的值,假如不存在page,那么页数就是1。

$num=10; //每页显示10条数据

$db=mysql_connect("host","name","pass"); //创建数据库连接

$select=mysql_select_db("db",$db); //选择要操作的数据库

/*

首先咱们要获取数据库中到底有多少数据,才能判断具体要分多少页,具体的公式就是

总数据数除以每页显示的条数,有余进一。

也就是说10/3=3.3333=4 有余数就要进一。

*/

$total=mysql_num_rows(mysql_query("select id from table")); //查询数据的总数,id是数据库中的一个自动赋值的字段

$pagenum=ceil($total/$num); //获得总页数

//假如传入的页数参数大于总页数,则显示错误信息

If($page>$pagenum || $page == 0){

Echo "Error : Can Not Found The page .";

Exit;

}

$offset=($page-1)*$num; //获取limit的第一个参数的值,假如第一页则为(1-1)*10=0,第二页为(2-1)*10=10。

$info=mysql_query("select name from table limit $offset,$num"); //获取相应页数所需要显示的数据,name是数据里的一个字段

While($it=mysql_fetch_array($info)){

Echo $it['name']."

";

} //显示数据

For($i=1;$i<=$pagenum;$i++){

$show=($i!=$page)?"$i":"$i";

Echo $show." ";

}

/*显示分页信息,假如是当页则显示粗体的数字,其余的页数则为超连接,假如当前为第三页则显示如下

1 2 3 4 5 6

*/

?>

用php怎样完成数字分页

你首先你要查询你总条数 total

你要设定一个变量 num 作为每页的数量

用total除以num 如果整除则为这个数组 如果有余则为这个数+1

然后确定当前第几页 limit  页数*num , num

将页数总数返回到前端

前端接接受到这个页数后 for一个a标签

php中怎么分页

<html>

<head>

<title>分页显示</title>

</head>

<script language="javascript">

function confirmDel()

{

var confirm=window.confirm("您确定要删除吗?");

if(confirm)

return true;

else

return false;

}

</script>

<body bgcolor="cce8cf">

<center>

<table border="1" width="90%" cellspacing="1">

<tr bgcolor="yellow">

<td>用户ID</td>

<td>用户名</td>

<td>密码</td>

<td>性别</td>

<td>年龄</td>

<td>电子邮件</td>

<td>操作</td>

</tr>

<?php

error_reporting(0);

//设置页大小,即每页显示几条数据

$pagesize=10;

//设置第一页

$page=1;

//数据库初始化操作

$link=mysql_connect("localhost","root","root");//连接数据库

$db=mysql_select_db("HibernateDemo",$link);//选择数据库

$sql="select count(*) from userinfo";//构造sql语句

$res=mysql_query($sql);//执行查询操作,结果为总记录数

$row=mysql_fetch_array($res);//取出一条记录

$rows=$row[0];//取出总记录数

//判断一共多少页

$pages=intval($rows/$pagesize);//取整数页,总页数

if($rows%$pagesize)

$pages=$pages+1;//如果还有余数的话,那么就再加一页来显示剩余的记录

//获取用户请求,即用户提交要去哪一页

$page=$_GET["ToPage"];

//整理用户输入

if($page<=0)

{

$page=1;//因为开始的时候没$page有值,所以是0,所以就让$page=1,这样后面的

//$page也就是1,见第97行

}

if($page>=$pages)

{

$page=$pages;

}

session_start();

echo "<div align='right' top='0'><a href='logout.php'>注销".$_SESSION['username']."</a></div>";

echo "当前第".$page."页,每页10个记录,总".$rows."条记录,一共".$pages."页";//显示页数信息

//计算偏移量

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

//构造sql语句

$sqlx="select * from userinfo limit 10 offset ".$offset;

$result=mysql_query($sqlx);//执行查询操作

$ok=mysql_fetch_array($result);

while($ok)

{

?>

<tr>

<td bgcolor="#DEB887"><?php echo $ok[0] ?></td>

<td><?php echo $ok[1] ?></td>

<td><?php echo $ok[2] ?></td>

<td><?php echo $ok[3]==male?"男":"女" ?></td>

<td><?php echo $ok[4] ?></td>

<td><?php echo $ok[5] ?></td>

<td><a href="updateInfo.php?userid=<?php echo $ok[0] ?>">修改</a>

<a href="deleteInfo.php?userid=<?php echo $ok[0] ?>"

onclick="return confirmDel();">删除</a>

</td>

</tr>

<?php

$ok=mysql_fetch_array($result);

}

?>

</table>

<table>

<?php

//判断当前是否是第一页,不是,则显示'第一页'和'上一页'

if($page!=1)

{

?>

<tr>

<td align="center">

<a href="pageSelect.php?ToPage=1">第一页</a>

<a href="pageSelect.php?ToPage=<?php echo ($page-1) ?>">上一页</a>

</td>

<?php

}

//如果不是最后一页,则显示‘最后一页’和‘下一页’

if($page!=$pages)

{

?>

<td align="center" colspan="6">

<a href="pageSelect.php?ToPage=<?php echo ($page+1) ?>">下一页</a>

<a href="pageSelect.php?ToPage=<?php echo ($pages) ?>">最后一页</a>

</td>

<?php

}

?>

<table>

<form action="pageSelect.php" method="get" name="form1">

<tr>

<td colspan="6" align="center">

<input type="text" value="<?php echo ($page) ?>" name="ToPage"

size="3" />

<a href="javascript:window.document.form1.submit();">GO</a>

</td>

</tr>

</form>

</table>

</center>

</body>

</html>

关于php分页选择页数的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。

查看更多关于php分页选择页数 php分页函数封装的详细内容...

声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did195088
更新时间:2023-04-26   阅读:15次

上一篇: 包含php当前时间time的词条

下一篇:php字面数组 php将数组以字母先后顺序排序

相关资讯

最新资料更新

  • 1.php判断08数字 php 判断数字
  • 2.phphint插件下载 php 插件系统
  • 3.如何阅读php源码 php在线源码获取
  • 4.php7性能tu Php性能
  • 5.php缓存框架 php 缓存
  • 6.phppngjpeg的简单介绍
  • 7.php编写确认密码 php用户名密码
  • 8.php多条件动态筛选 php实现数据筛选
  • 9.php获取监控视频 php采集视频地址
  • 10.php中文注释乱码 php注释语句
  • 11.php如何制作游戏 php游戏源码
  • 12.php表示数组元素 php数组实现
  • 13.php配置外网访问 phpstudy外网映射
  • 14.php图片打不开 php打不开文件
  • 15.php的环境安装 phpstudy安装环境
  • 16.php单个会话内存 php会话保存数据的两种方式是
  • 17.zblogphp分类 zblog asp
  • 18.php判断字符串的编码 php 判断字符串是否存在某个字符串
  • 19.php消息通知实例的简单介绍
  • 20.php区xml文件 php处理xml数据

CopyRight:2016-2025好得很程序员自学网 备案ICP:湘ICP备09009000号-16 http://haodehen.cn
本站资讯不构成任何建议,仅限于个人分享,参考须谨慎!
本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。
本网站刊载的所有内容(包括但不仅限文字、图片、LOGO、音频、视频、软件、程序等)版权归原作者所有。任何单位或个人认为本网站中的内容可能涉嫌侵犯其知识产权或存在不实内容时,请及时通知本站,予以删除。

网站内容来源于网络分享,如有侵权发邮箱到:kenbest@126.com,收到邮件我们会即时下线处理。
网站框架支持:HDHCMS   51LA统计 百度统计
Copyright © 2018-2025 「好得很程序员自学网」
[ SiteMap ]