-
php分页函数完整实例代码
这篇文章主要介绍了php分页函数完整实例代码,采用较为详尽的注释说明了PHP分页的方法及原理,需要的朋友可以参考下。
本文分享一例php分页函数完整实例代码,使用此函数实现分页效果很不错。分享给大家供大家参考。
具体功能代码如下:
- <?php
- /*
- * Created on 2011-07-28
- * 使用方法:
- require_once('mypage.php');
- $result=mysql_query("select * from mytable", $myconn);
- $total=mysql_num_rows($result); //取得信息总数
- pageDivide($total,10); //调用分页函数
- //数据库操作
- $result=mysql_query("select * from mytable limit $sqlfirst,$shownu", $myconn);
- while($row=mysql_fetch_array($result)){
- //...您的操作
- }
- echo $pagecon; //输出分页导航内容
- */
- if(!function_exists("pageDivide")){
- #$total 信息总数
- #$shownu 显示数量,默认20
- #$url 本页链接
- function pageDivide($total,$shownu=20,$url=''){
- #$page 当前页码
- #$sqlfirst mysql数据库起始项
- #$pagecon 分页导航内容
- global $page,$sqlfirst,$pagecon,$_SERVER;
- $GLOBALS["shownu"]=$shownu;
- if(isset($_GET['page'])){
- $page=$_GET['page'];
- }else $page=1;
- #如果$url使用默认,即空值,则赋值为本页URL
- if(!$url){ $url=$_SERVER["REQUEST_URI"];}
- #URL分析
- $parse_url=parse_url($url);
- @$url_query=$parse_url["query"]; //取出在问号?之后内容
- if($url_query){
- $url_query=preg_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($total/$shownu); //最后页,总页数
- $page=min($lastpg,$page);
- $prepg=$page-1; //上一页
- $nextpg=($page==$lastpg ? 0 : $page+1); //下一页
- $sqlfirst=($page-1)*$shownu;
- #开始分页导航内容
- $pagecon = "显示第 ".($total?($sqlfirst+1):0)."-".min($sqlfirst+$shownu,$total)." 条记录,共 <B>$total</B> 条记录";
- if($lastpg<=1) return false; //如果只有一页则跳出
- if($page!=1) $pagecon .=" <a href='$url=1'>首页</a> "; else $pagecon .=" 首页 ";
- if($prepg) $pagecon .=" <a href='$url=$prepg'>前页</a> "; else $pagecon .=" 前页 ";
- if($nextpg) $pagecon .=" <a href='$url=$nextpg'>后页</a> "; else $pagecon .=" 后页 ";
- if($page!=$lastpg) $pagecon.=" <a href='$url=$lastpg'>尾页</a> "; else $pagecon .=" 尾页 ";
- #下拉跳转列表,循环列出所有页码
- $pagecon .=" 到第 <select name='topage' size='1' onchange='window.location=\"$url=\"+this.value'>\n";
- for($i=1;$i<=$lastpg;$i++){
- if($i==$page) $pagecon .="<option value='$i' selected>$i</option>\n";
- else $pagecon .="<option value='$i'>$i</option>\n";
- } //www.phpfensi.com
- $pagecon .="</select> 页,共 $lastpg 页";
- }
- }else die('pageDivide()同名函数已经存在!');
- ?>
相信本文所述对大家PHP程序设计的学习有一定的借鉴价值。
出处:http://www.phpfensi.com/php/20210412/14243.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式