<?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. 搭建企业cacti服务器

    搭建企业cacti服务器 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 今天搭建了cacti,为了方便监控我的交换机~因为查了很多zabbix的资料关于监控交换机的教程~我都屡屡失 ...

  2. zoj The 12th Zhejiang Provincial Collegiate Programming Contest Convert QWERTY to Dvorak

    http://acm.zju.edu.cn/onlinejudge/showContestProblem.do?problemId=5502  The 12th Zhejiang Provincial ...

  3. UML: 协作图

    摘自http://www.umlonline.org/school/thread-38-1-1.html UML1.1时,协作图英文名字叫:Collaboration Diagram,UML2.0时, ...

  4. hdu4609 3-idiots

    FFT 代码 #include<iostream> #include<cstring> #include<cstdio> #include<cmath> ...

  5. 基于时间点恢复数据库stopat

    create database newtestdb use newtestdbgo drop table t1go create table t1 (id int not null identity( ...

  6. 下拉框分组显示optgroup

    <select> <optgroup label="语言"> <option>中文</option> <option>英 ...

  7. Inside TSQL Querying - Chapter 2. Physical Query Processing

    Summary Description The SQL language is spoken by most database experts, and all relational database ...

  8. Openstack的vnc界面定制

    先来看一下青云的vnc界面: 在来看一下openstack的自带的vnc界面: 区别于感受 本身原理是一样的,但是vnc上面的html布局不一样而已,但是青云的vnc界面给人的感受是:清晰提示,信息给 ...

  9. loadrunner具体实例教你如何进行结果分析

    1.对于吞吐量,单位时间内吞吐量越大,说明服务器的处理能越好,而请求数仅表示客户端向服务器发出的请求数,与吞吐量一般是成正比关系. 2.一般瓶颈应该就是某个因素在不断增加,某个相关性能指标也会不断增加 ...

  10. bash

    unix - Unlimited Bash History - Stack Overflowhttp://stackoverflow.com/questions/9457233/unlimited-b ...