<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2016/6/22
* Time: 21:37
*/ Class Page{
protected $sum; //总记录数
protected $page_show; //每页显示多少记录
protected $totalpage; //总页数
protected $page; //当前页面
protected $limit;
protected $url;
protected $start; //开始
protected $end; //结束 function __construct($sum,$row=1)
{
$this->sum=$sum; //总记录数
$this->page_show=$row; //每页显示
$this->totalpage=ceil($this->sum/$this->page_show);//总页数
$this->url=$this->curUrl(); //地支
$this->page=$this->curPage(); //当前页 $this->start=($this->page-1)*$this->page_show; //起始页 }
//获取当前页
//min($this->totalpage,max((int)@$_GET['page'],1));
public function curPage()
{
if(!empty($_GET['page']))
{
if($_GET['page']>$this->totalpage)
{
$page=$this->totalpage;
}else{
$page=$_GET['page'];
}
}else{
$page=1;
}
return $page; } //获取当前地址
public function curUrl(){
// $_url=$_SERVER['REUQEST_URI']; //当前的Url
// $_par=parse_url($_url); //分解当前URL
// if(isset($_par['query']))
// {
//
// } $curUrl=isset($_SERVER['REQUEST_URI'])?$_SERVER['REQUEST_URI']:$_SERVER['PHP_SELF'].$_SERVER['QUERY_STRING'];
//解析字符串
$parseURL=parse_url($curUrl); //分解获取查询字符串
if(isset($parseURL['query']))
{
parse_str($parseURL['query'],$arr); //将字符串解析成变量,并放去数组中
unset($arr['page']);
//$curUrl=$parseURL['path']."?".http_build_query($arr);
$curUrl = $parseURL['path']."?".http_build_query($arr)."&page=";
//var_dump($curUrl);
}else{
$curUrl=strstr($curUrl,"?")?$curUrl."page=":$curUrl."?page=";
}
return $curUrl;
} //分页查询记录数
public function limit()
{
return "LIMIT {$this->start},{$this->page_show}";
} //上一页
public function pre()
{
return $this->page>1?"<a href='".$this->url.($this->page-1)."'>上一页</a>":'1';
} //下一页
public function next(){
return $this->page<$this->totalpage?"<a href='".$this->url.($this->page+1)."'>下一页</a>":'';
} //首页
public function index()
{
return $this->page>1?"<a href='{$this->url}1'>首页</a>":'1';
} //未接
public function end()
{
return $this->page<$this->totalpage?"<a href='{$this->url}{$this->totalpage}'>未页</a>":'';
}
//总页数
public function count()
{
return "<span>总页{$this->totalpage}  总计{$this->sum}条</span>";
} //页码数组
public function pagearray()
{
$pagelist=array();
for($i=1;$i<$this->totalpage;$i++)
{
if($i==$this->page){
$pagelist[$i]['url']="";
$pagelist[$i]['str']=$i;
continue;
}
$pagelist[$i]['url']=$this->url.$i;
$pagelist[$i]['str']=$i;
}
return $pagelist; } //下拉列表 public function select()
{
$arr=$this->pagearray();
$str="<select class='s' onchange='javascript:location.href=this.options[selectedIndex].value'>";
foreach($arr as $v)
{
$str.=empty($v['url'])?"<option value='{$this->url}{$v['str']}' selected='selected'>{$v['str']}</option>":"<option value='{$v['url']}'>{$v['str']}</option>";
}
$str.="</select>";
return $str;
} } $p=new Page(20);
echo $p->index();
echo "</br>";
//echo $p->curUrl();
echo "</br>";
echo $p->end();
echo $p->count();
echo $p->select();

  

PHP之分页类的更多相关文章

  1. php实现的分页类

    php分页类文件: <?php /** file: page.class.php 完美分页类 Page */ class Page { private $total; //数据表中总记录数 pr ...

  2. asp.net的快捷实用分页类

    KeleyiPager分页类,可以于对列表页进行分页浏览,代码是从HoverTreeCMS项目中COPY的,感觉很不错,使用简单方便,但是功能强大. 在线体验效果:http://cms.hovertr ...

  3. php分页类

    1.需求 学会php分页类的使用 2.参考例子 CI的分页类 3.代码部分 <?php class pagination{ public $pagesize=20; public $pagein ...

  4. PHPCMS V9 分页类的修改教程

    首先,打开 phpcms\libs\functions\global.func.php 这个文件,找到文件第622行的分页函数,复制一下,粘贴到默认分页函数的下面,重新命名后保存.(笔者在此命名为:p ...

  5. php 简单分页类

    /**  file: page.class.php   完美分页类 Page  */ class Page {  private $total;          //数据表中总记录数  privat ...

  6. PHP简单漂亮的分页类

    本文介绍一款原生的PHP分页类,分页样式有点类似bootstrap. <?php /* * ********************************************* * @类名 ...

  7. ThinkPHP 分页类的使用及退出功能的实现

    /* ThinkPHP设置编码统一: 一.数据库设置为utf8_bin 二.HTML页面设置charset=utf-8,而且检查文档编码格式是否是utf-8.phpDesigner8设置方式为“文件- ...

  8. php部分---一个分页类、用法

    1.分页类 <?php /** file: page.class.php 完美分页类 Page */ class Page { private $total; //数据表中总记录数 privat ...

  9. DedeCMS织梦动态分页类,datalist标签使用实例

    <?php require_once(dirname(__FILE__)."/include/common.inc.php");//载入基础文件 require_once(D ...

  10. webpy分页类 + 上传类

    webpy没有分页类.按照php的思路.自己编了一个.数据库用的是sqlite. class Page(object): '''分页类''' def __init__(self,page_size,d ...

随机推荐

  1. 使用dbms_system追踪其它session

    dbms_system是内部包,建议在官方指导下使用该包. SQL> desc dbms_system PROCEDURE ADD_PARAMETER_VALUE Argument Name T ...

  2. Oracle 10046跟踪事件使用方法

    1.开启10046跟踪事件 alter session set events '10046 trace name context forever, level 12'; 如果想更容易标识trace文件 ...

  3. 通用窗口类 Inventory Pro 2.1.2 Demo1(下)

    本篇想总结的是Inventory Pro中通用窗口的具体实现,但还是要强调下该插件的重点还是装备系统而不是通用窗口系统,所以这里提到的通用窗口类其实是通用装备窗口类(其实该插件中也有非装备窗口比如No ...

  4. G面经prepare: Sort String Based On Another

    Given a sorting order string, sort the input string based on the given sorting order string. Ex sort ...

  5. [原创]java WEB学习笔记66:Struts2 学习之路--Struts的CRUD操作( 查看 / 删除/ 添加) 使用 paramsPrepareParamsStack 重构代码 ,PrepareInterceptor拦截器,paramsPrepareParamsStack 拦截器栈

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  6. paper 39 :Matlab绘制误差棒图(errorbar函数的使用)

    同很多非数学相关专业的朋友一样,我第一次碰到这个图时也是丈二和尚摸不着头脑.只知道这个工字型的图案,中间的点代表的是平均值,上下的两条横线代表的是方差值,除此之外,连这个图叫什么名字都不知道,只好硬着 ...

  7. PAT乙级 1019. 数字黑洞 (20)

    1019. 数字黑洞 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定任一个各位数字不完全相同的4位 ...

  8. C# 文件读取(二)

    将我的电脑中的文件夹信息显示到TreeView控件上. 方法很多种,下面这种方法添加了我的文档. public partial class Form1 : Form { public Form1() ...

  9. [Mongo] How to Install Mongo on Debian(不要安装)

    Install MongoDB on Debian¶ This tutorial outlines the steps to install MongoDB on Debian systems. Th ...

  10. dota玩家与英雄契合度的计算器,python语言scrapy爬虫的使用

    首发:个人博客,更新&纠错&回复 演示地址在这里,代码在这里. 一个dota玩家与英雄契合度的计算器(查看效果),包括两部分代码: 1.python的scrapy爬虫,总体思路是pag ...