php分页类函数,php分页类的使用方法
PHP分页类是一个比较有用的类,如何灵活的运用这个类来帮助我们完成功能的实现是一个程序员必备的知识。下面由学习啦小编整理了几种php分页类的使用方法,希望对大家有所帮助。
php分页类的使用方法(一)
/*
分页类 用于实现对多条数据分页显示
version:1.0
Date:2013-10-20
*/
/*
调用非常方便,先连接好数据库,直接传人查询的sql字符串即可,也可以指定每页显示的数据条数
例如$pages = new Page('SELECT * FROM `zy_common_member`');
或 $pages = new Page('SELECT * FROM `zy_common_member`', 10);
*/
class Page{
private $curPage;
private $totalPages;//数据总共分多少页显示
private $dispNum;//每页显示的数据条数
private $queryStr;//查询的SQL语句
private $limitStr;//查询语句后面的limit控制语句
/*
构造函数
$queryStr 查询数据的SQL语句
$dispNum 每页显示的数据条数
*/
public function __construct($queryStr='',$dispNum=10){
$result = mysql_query($queryStr);
$totalNum = mysql_num_rows($result);
$this->dispNum = $dispNum;
$this->totalPages = ceil($totalNum / $dispNum);
$this->queryStr = $queryStr;
$temp = (isset($_GET["curPage"]) ? $_GET["curPage"] : 1);
$this->setCurPage($temp);
$this->showCurPage();
$this->showFoot();
}
/*显示当前页的数据内容*/
private function showCurPage(){
$this->limitStr = ' LIMIT '.(($this->curPage - 1)* $this->dispNum).','.$this->dispNum;
//echo $this->queryStr.$this->limitStr;
$result = mysql_query($this->queryStr.$this->limitStr);
if (!$result)
{
if ($this->totalPages > 0)
{
echo '查询出错'.'
';
}
else
{
echo '无数据'.'
';
}
return;
}
$cols = mysql_num_fields($result);
echo '
echo '
';
for($i=0; $i
{
echo '
';
echo mysql_field_name($result, $i);
echo '
';
}
echo '
';
while($row = mysql_fetch_assoc($result))
{
echo '
';
foreach($row as $key=>$value)
{
echo '
';
echo $value;
echo '
';
}
echo '
';
}
echo '
';
}
private function setCurPage($curPage){
if($curPage < 1)
{
$curPage = 1;
}
else if($curPage > $this->totalPages)
{
$curPage = $this->totalPages;
}
$this->curPage = $curPage;
}
/*
显示分页页脚的信息
如首页,上一页,下一页,尾页等信息
*/
private function showFoot(){
echo '首页';
echo '上一页';
echo '下一页';
echo '尾页';
}
}
?>
php分页类的使用方法(二)
< ?php
//为了避免重复包含文件而造成错误,
加了判断函数是否存在的条件:
if(!function_exists(pageft)){
//定义函数pageft(),三个参数的含义为:
//$totle:信息总数;
//$displaypg:每页显示信息数,这里设置为默认是20;
//$url:分页导航中的链接,除了加入不同的
查询信息“page”外的部分都与这个URL相同。
//默认值本该设为本页URL(即$_SERVER
["REQUEST_URI"]),但设置默认值的右边
只能为常量,所以该默认值设为空字符串,在函数内部再设置为本页URL。
function pageft($totle,$displaypg=20,$url=''){
//定义几个全局变量:
//$page:当前页码;
//$firstcount:(数据库)查询的起始项;
//$pagenav:页面导航条代码,函数内部并没有将它输出;
//$_SERVER:读取本页URL“$_SERVER["REQUEST_URI"]”所必须。
global $page,$firstcount,$pagenav,$_SERVER;
//为使函数外部可以访问这里的“$displaypg”,将它也设为全局变量。注意一个变量重新定义,为全局变量后,原值被覆盖,所以这里给它重新赋值。
$GLOBALS["displaypg"]=$displaypg;
if(!$page) $page=1;
//如果$url使用默认,即空值,则赋值为本页URL:
if(!$url){ $url=$_SERVER["REQUEST_URI"];}
//URL分析:
$parse_urlparse_url=parse_url($url);
$url_query=$parse_url["query"]; //单独取出URL的查询字串
if($url_query){
//因为URL中可能包含了页码信息,
我们要把它去掉,以便加入新的页码信息。
//这里用到了正则表达式
$url_query=ereg_replace("(^|&)page=$page","",$url_query);
//将处理后的URL的查询字串替换原来的URL的查询字串:
$url=str_replace($parse_url["query"],$url_query,$url);
//在URL后加page查询信息,但待赋值:
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="显示第 ".($totle?($firstcount+1):0)."
-".min($firstcount+$displaypg,$totle)."
条记录,共 $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' οnchange='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.="
$i< /option>n";
}
$pagenav.="< /select> 页,共 $lastpg 页";
}
}
?>
php分页类的使用方法(三)
// 方法调用:
$pages = new Pages($perpage, $count, $page, 'showpage.php?page'); 创建对象
$pages->setShowPageNum($num); 设置显示的页数
$pages->setCurrentIndexPage($num); 设置当前页在分页栏中的位置
$pages->setFirstPageText($text); 设置链接第一页显示的文字
$pages->setLastPageText($text); 设置链接最后一页显示的文字
$pages->setPrePageText($text); 设置链接上一页显示的文字
$pages->setNextPageText($text); 设置链接下一页显示的文字
$pages->setPageCss($css); 设置各分页码css样式的class名称
$pages->setCurrentPageCss($css); 设置当前页码css样式的class名称
$pages->setPageStyle($style); 设置各分页码的样式,即style属性
$pages->setCurrentPageStyle($style); 设置当前页码的样式,即style属性
$pages->setLinkSymbol('='); 设置地址链接中页码与变量的连接符,如page=2中的“=”
$pages->isShowFirstAndLast(true); 设置是否显示第一页与最后一页的链接
$pages->isShowForSimplePage(true); 设置当只有一页时是否显示分页
$pageCount = $pages->getTotalPageNum(); 获取总页数
?>
//分页类
class Pages{
private $eachDisNums; //每页显示的条目数
private $nums; //总条目数
private $currentPage; //当前被选中的页
private $showPageNum = 5; //每次显示的页数
private $curIndexPage = 3; //当前页在分页中的位置
private $totalPageNum; //总页数
private $arrPage = array(); //用来构造分页的数组
private $subPageLink; //每个分页的链接
private $firstPageText = '1..'; //第一页显示的文字
private $lastPageText; //最后一页显示的文字
private $prePageText = '
private $nextPageText = '>'; //下一页显示的文字
private $pageCss = ''; //一般页的样式名称
private $curPageCss = ''; //当前页的样式名称
private $pageStyle = ''; //一般页的样式
private $curPageStyle = ''; //当前页的样式
private $linkSymbol = '='; //url链接地址中page与页数之间的符号
private $isShowFirstLast = true; //是否显示第一页和最后一页
private $isShowForSimplePage = false; //当没有分页时(即总条目数不大于每页显示的条目数)是否显示分页栏
/**
* 设置显示的页数
*
* @param integer $num 显示的页数
* @return void
*/
public function setShowPageNum($num){
$this->showPageNum = $num;
}
/**
* 设置当前页在分页栏中的位置
*
* @param integer $num 当前页在分页栏中的位置
* @return void
*/
public function setCurrentIndexPage($num){
$this->curIndexPage = $num;
}
/**
* 设置链接第一页显示的文字
*
* @param string $text 要显示的文字
* @return void
*/
public function setFirstPageText($text){
$this->firstPageText = $text;
}
/**
* 设置链接最后一页显示的文字
*
* @param string $text 要显示的文字
* @return void
*/
public function setLastPageText($text){
$this->lastPageText = $text;
}
/**
* 设置链接上一页显示的文字
*
* @param string $text 要显示的文字
* @return void
*/
public function setPrePageText($text){
$this->prePageText = $text;
}
/**
* 设置链接下一页显示的文字
*
* @param string $text 要显示的文字
* @return void
*/
public function setNextPageText($text){
$this->nextPageText = $text;
}
/**
* 设置各分页码css样式的class名称
*
* @param string $css css样式名称
* @return void
*/
public function setPageCss($css){
$this->pageCss = $css;
}
/**
* 设置当前页码css样式的class名称
*
* @param string $css css样式名称
* @return void
*/
public function setCurrentPageCss($css){
$this->curPageCss = $css;
}
/**
* 设置各分页码的样式,即style属性
*
* @param string $style style样式
* @return void
*/
public function setPageStyle($style){
$this->pageStyle = $style;
}
/**
* 设置当前页码的样式,即style属性
*
* @param string $style style样式
* @return void
*/
public function setCurrentPageStyle($style){
$this->curPageStyle = $style;
}
/**
* 设置地址链接中页码与变量的连接符,如page=2中的“=”
*
* @param string $symbol 连接符号
* @return void
*/
public function setLinkSymbol($symbol){
$this->linkSymbol = $symbol;
}
/**
* 获取总页数
*
* @access private
* @return integer
*/
public function getTotalPageNum(){
return $this->totalPageNum;
}
/**
* 设置是否显示第一页与最后一页的链接
*
* @param boolean $is true:显示,false:不显示
* @return void
*/
public function isShowFirstAndLast($is){
$this->isShowFirstLast = $is;
}
/**
* 设置当只有一页时是否显示分页
*
* @param boolean $is true:显示,false:不显示
* @return void
*/
public function isShowForSimplePage($is){
$this->isShowForSimplePage = $is;
}
/**
* 构造方法
*
* @param integer $eachDisNums 每页显示的条目数
* @param integer $nums 总条目数
* @param integer $current_num 当前被选中的页
* @param integer $showPageNum 每次显示的页数
* @param integer $subPageLink 每个分页的链接
* @param integer $subPage_type 显示分页的类型
* @return void
*/
public function __construct($eachDisNums, $nums, $currentPage, $subPageLink){
$this->eachDisNums=intval($eachDisNums);
$nums = $nums==0 ? 1: $nums;
$this->nums = intval($nums);
$this->totalPageNum = ceil($nums/$eachDisNums);
$this->currentPage =intval($currentPage);
$this->currentPage = $this->currentPage<=0 ? 1: $this->currentPage;
$this->currentPage = $this->currentPage > $this->totalPageNum ? 1 : $this->currentPage;
$this->subPageLink = $subPageLink;
$this->lastPageText = '..'.$this->totalPageNum;
}
public function __destruct(){
unset($this->eachDisNums);
unset($this->nums);
unset($this->currentPage);
unset($this->showPageNum);
unset($this->curIndexPage);
unset($this->totalPageNum);
unset($this->arrPage);
unset($this->subPageLink);
unset($this->firstPageText);
unset($this->lastPageText);
unset($this->prePageText);
unset($this->nextPageText);
unset($this->pageCss);
unset($this->curPageCss);
unset($this->pageStyle);
unset($this->curPageStyle);
unset($this->linkSymbol);
unset($this->isShowFirstLast);
unset($this->isShowForSimplePage);
}
/**
* 生成分页
*
* @return string
*/
public function generatePages(){
$subPageCss2Str = '';
$isShow = false;
if($this->totalPageNum == 1){ //只有一页时
if($this->isShowForSimplePage){
$isShow = true;
}
}else{
$isShow = true;
}
if($isShow){
if($this->currentPage > 1){
$prewPageUrl = $this->subPageLink.$this->linkSymbol.($this->currentPage-1);
if($this->isShowFirstLast){
$firstPageUrl = $this->subPageLink.$this->linkSymbol."1";
$subPageCss2Str .= ''.$this->firstPageText.'';
}
$subPageCss2Str .= ''.$this->prePageText.'';
}
$a=$this->construct_num_Page();
for($i=0;$i
$s=$a[$i];
if($s == $this->currentPage ){
$subPageCss2Str .= ''.$s.'';
}else{
$url = $this->subPageLink.$this->linkSymbol.$s;
$subPageCss2Str .= ''.$s.'';
}
}
if($this->currentPage < $this->totalPageNum){
$nextPageUrl = $this->subPageLink.$this->linkSymbol.($this->currentPage+1);
$subPageCss2Str .= ''.$this->nextPageText.'';
if($this->isShowFirstLast){
$lastPageUrl = $this->subPageLink.$this->linkSymbol.$this->totalPageNum;
$subPageCss2Str .= ''.$this->lastPageText.' ';
}
}
}
return $subPageCss2Str;
}//End of generatePages() Method
/**
* 用来给建立分页的数组初始化的函数。
*
* @return array
*/
private function initArray(){
for($i=0; $i < $this->showPageNum; $i ++){
$this->arrPage[$i] = $i;
}
return $this->arrPage;
}//End of initArray() Method
/**
* 用来构造显示的条目
* 即:[1][2][3][4][5][6][7][8][9][10]
*
* @return array
*/
private function construct_num_Page(){
if($this->totalPageNum < $this->showPageNum){
$currentArray = array();
for($i=0; $i < $this->totalPageNum; $i ++){
$currentArray[$i] = $i + 1;
}
}else{
$currentArray = $this->initArray();
$curArrayLen = count($currentArray);
if($this->currentPage <= $this->curIndexPage){
for($i=0; $i < $curArrayLen; $i ++){
$currentArray[$i] = $i+1;
}
}elseif (($this->currentPage <= $this->totalPageNum) && ($this->currentPage > ($this->totalPageNum - $this->showPageNum + 1))){
//构造最后的分页栏,35 36 37 38 39 40 [下一页] [最后一页] 总页数为40
for($i=0; $i < $curArrayLen; $i ++){
$currentArray[$i] = $this->totalPageNum - $this->showPageNum + 1 + $i;
}
}else{
for($i=0; $i < $curArrayLen; $i ++){
$currentArray[$i] = $this->currentPage - $this->curIndexPage + 1 +$i;
}
}
}
return $currentArray;
}//End of construct_num_Page() Method
}//End of Pages Class
?>
猜你喜欢:
php分页类函数,php分页类的使用方法相关推荐
- 分页封装实用工具类及其使用方法
分页封装实用工具类及其使用方法 作者: javaboy2012 Email:yanek@163.com qq: 1046011462 package com.yanek.util; import ...
- 【Flask项目2】python对象分页数据序列化基类(5)
comment-utils-serializer.py文件 class BasePaginateSerializer(object):"""分页数据序列化基类" ...
- ThinkPHP3验证码、文件上传、缩略图、分页(自定义工具类、session和cookie)
验证码 TP框架中自带了验证码类 位置:Think/verify.class.php 在LoginController控制器中创建生存验证码的方法 login.html登陆模板中 在LoginCont ...
- ssm整合oracle分页,java实现ssm分页工具类及其使用方法
分享一下我现在所使用的分页工具类,不像网上的那么规范 纯属自己总结根据逻辑敲出来的,基于mysql的limit来做分页.有不对的地方还望大佬指出,直接上代码 PageTools package com ...
- 分页的php处理,分页处理的PHP类
分页处理的PHP类 namespace JasonGrimes; class Paginator { const NUM_PLACEHOLDER = '(:num)'; protected $tota ...
- 【第二版】RichFaces中使用datatable和datascroller进行分页(使用数据库分页,改良版)(含源码)(JSF 1.2,RichFaces 3.2.1GA)
之前第一版有个问题,就是如果进行了删除等操作并立即返回列表页,被删除的项还在那,但其实数据库已经被删除了,需要做一个刷新列表操作才可以,本版就是修正此问题的. 如果要修正此问题,就需要将分页的扩展代码 ...
- 数据分页 THINKPHP3.2 分页 三种分页方法
数据分页复制本页链接opensns 通常在数据查询后都会对数据集进行分页操作,ThinkPHP也提供了分页类来对数据分页提供支持. 下面是数据分页的两种示例.第一种:利用Page类和limit方法$U ...
- bootstraptable控制分页_bootstrap table分页(前后端两种方式实现)
bootstrap table分页的两种方式: 前端分页:一次性从数据库查询所有的数据,在前端进行分页(数据量小的时候或者逻辑处理不复杂的话可以使用前端分页) 服务器分页:每次只查询当前页面加载所需要 ...
- DRF url控制 解析器 响应器 版本控制 分页(常规分页,偏移分页,cursor游标分页)...
url控制 第二种写法(只要继承了ViewSetMixin) url(r'^pub/$',views.Pub.as_view({'get':'list','post':'create'})), #获取 ...
- java sql分页_mysql、sqlserver、oracle分页,java分页统一接口实现
定义:pageStart 起始页,pageEnd 终止页,pageSize页面容量 oracle分页: select * from ( select mytable.*,rownum num from ...
最新文章
- L1-006 连续因子
- 【BZOJ3196】Tyvj 1730 二逼平衡树
- 转载:身体器官工作表一览,睡觉别太晚了
- 初学者phthon笔记(异常处理)
- 什么是AWT_Swing_Vector?居然这么高频使用
- 触控获取坐标判断滑动方向
- Stream Processing With Flink (7) 状态算子和用户函数
- 深入理解高级数据结构之红黑树
- 关于C语言的随机函数
- aardio获取数据乱码问题
- LVGL-输入设备LV_INDEV_TYPE_POINTER类型
- Linux全套完整视频教程
- 【Unity3D自学记录】Unity Standard Assets 简介之 Characters
- 基于51单片机智能温度控制器温控系统(毕设课设)
- matlab diff函数
- 华为手机有线共享网络_华为怎么共享热点网络连接(图文)
- html中video视频播放
- Scratch教程——月亮公转和地球自转
- 波长、子载波、载波容量和波长容量、频谱效能(针对光通信来说)
- java 60进制运算_Java【第二篇】基本语法之--进制、运算符
热门文章
- 安卓设备java代码编辑器_15款android设备上的代码编辑器,超级方便!-Go语言中文社区...
- 限制编辑的PDF文档没有密码如何破解?
- 使用java语言实现一个动态数组(详解)(数据结构)
- 比例电磁阀(零)液压知识
- 自己做量化交易软件(42)小白量化实战15--自编股票软件公式历史与聚宽量化平台仿大智慧指标回测设计
- 神经网络建模的基本思想,三维建模神经网络设计
- 计算机信息检索自考知识点,计算机信息检索02139自考资料.doc
- 红外测距模块–红外对管(TCRT5000)原理
- 用matlab做一元线性回归画图,[转载]用matlab做一元线性回归分析
- H5唤起 uniapp 版的app 端