`
asstudio
  • 浏览: 7212 次
社区版块
存档分类
最新评论

取自一个框架的分页类(优点调用简单,显示方便)

php 
阅读更多
使用方法:
第一步:include 'lib/page.php';
                        //引入文件
第二步:$page=new Page($musiclist->findCount(),5);
                        //实例化类,并传入数据总数和分页数
第三步:$this->results = $musiclist->findAll(null, "music_time DESC ",null,$page->limit);
                         //查找数据时将$page->limit传入
第四步:$this->pages = $page->fpage(4,5,6,0,2);
                         //显示分页
$this->display("music01/admin/music.html");
    总结: 上例是SMARTY里面使用的方法:页面直接写{<$page>}  就可以显示了。
           $page->fpage(4,5,6,0,2);输入数字的不同可以显示不同的效果。


<?php
class Page {
private $total;    //数据表中总记录数
private $listRows; //每页显示行数
private $limit;    //SQL语句使用limit从名
private $uri;      //url地址
private $pageNum;  //页数
private $page;
//在分页信息中显示内容,可以自己设置
private $config=array('head'=>"条记录", "prev"=>"上一页", "next"=>"下一页", "first"=>"首页", "last"=>"末页");
private $listNum=10; //默认分页列表显示的个数

/**
* 构造方法,可以设置分页类的属性
* @param int $total 计算分页的总记录数
* @param int $listRows 可选的,默认每页需要显示的记录数
* @param string $pa 可选的,为向目标页面传递参数
* @param bool $ord    可选的,默认值为true, 如果为true默认页为第一页,false则为最后一页
*/
public function __construct($total, $listRows=25, $pa="", $ord=true){
$this->total=$total;
$this->listRows=$listRows;
$this->uri=$this->getUri($pa);
$this->pageNum=ceil($this->total/$this->listRows);
if(!empty($_GET["page"])) {
$page=$_GET["page"];
}else{
if($ord)
$page=1;
else
$page=$this->pageNum;
}

if($total > 0) {
if(preg_match('/\D/', $page) ){
$this->page=1;
}else{
$this->page=$page;
}
}else{
$this->page=0;
}


$this->limit=$this->setLimit();
}

/**
* 用于设置显示分页的信息,可以连贯操作
* @param string $param 是数组config的下标
* @param string $value 用于设置config下标对应的元素值
* @return object 返回本对象自己$this
*/
function set($param, $value){
if(array_key_exists($param, $this->config)){
$this->config[$param]=$value;
}
return $this;
}

private function setLimit(){
if($this->page > 0)
return ($this->page-1)*$this->listRows.", {$this->listRows}";
else
return 0;
}

private function getUri($pa){
if($pa==""){
return $_SERVER['PHP_SELF'].'?c='.$_GET["c"].'&a='.$_GET["a"].'&';
                }else{
return $_SERVER['PHP_SELF'].'?c='.$_GET["c"].'&a='.$_GET["a"].'&'.$pa.'='.$_GET[$pa].'&';
}
}

private function __get($args){
if($args=="limit" || $args=="page")
return $this->$args;
else
return null;
}

private function start(){
if($this->total==0)
return 0;
else
return ($this->page-1)*$this->listRows+1;
}

private function end(){
return min($this->page*$this->listRows,$this->total);
}

private function firstprev(){
if($this->page > 1) {
$str="&nbsp;<a href='{$this->uri}page=1'>{$this->config["first"]}</a>";
$str.="&nbsp;<a href='{$this->uri}page=".($this->page-1)."'>{$this->config["prev"]}</a>&nbsp;";
return $str;
}

}


private function pageList(){
$linkPage="&nbsp;<b>";

$inum=floor($this->listNum/2);

for($i=$inum; $i>=1; $i--){
$page=$this->page-$i;

if($page>=1)
$linkPage.="<a href='{$this->uri}page={$page}'>{$page}</a>&nbsp;";

}

if($this->pageNum > 1)
$linkPage.="<span style='padding:1px 2px;background:#BBB;color:white'>{$this->page}</span>&nbsp;";


for($i=1; $i<=$inum; $i++){
$page=$this->page+$i;
if($page<=$this->pageNum)
$linkPage.="<a href='{$this->uri}page={$page}'>{$page}</a>&nbsp;";
else
break;
}
$linkPage.='</b>';
return $linkPage;
}

private function nextlast(){
if($this->page != $this->pageNum) {
$str="&nbsp;<a href='{$this->uri}page=".($this->page+1)."'>{$this->config["next"]}</a>&nbsp;";
$str.="&nbsp;<a href='{$this->uri}page=".($this->pageNum)."'>{$this->config["last"]}</a>&nbsp;";
return $str;
}

}

private function goPage(){
    if($this->pageNum > 1) {
return '&nbsp;<input style="width:20px;height:17px !important;height:18px;border:1px solid #CCCCCC;" type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>'.$this->pageNum.')?'.$this->pageNum.':this.value;location=\''.$this->uri.'page=\'+page+\'\'}" value="'.$this->page.'"><input style="cursor:pointer;width:25px;height:18px;border:1px solid #CCCCCC;" type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>'.$this->pageNum.')?'.$this->pageNum.':this.previousSibling.value;location=\''.$this->uri.'page=\'+page+\'\'">&nbsp;';
}
}

private function disnum(){
if($this->total > 0){
return $this->end()-$this->start()+1;
}else{
return 0;
}
}
/**
* 按指定的格式输出分页
* @param int 为0-7的数字,每个数字作为一个参数,可以自定义输出分页结构和调整结构的顺序
* @return string 分页信息内容
*/
function fpage(){
$arr=func_get_args();

$html[0]="&nbsp;共<b> {$this->total} </b>{$this->config["head"]}&nbsp;";
$html[1]="&nbsp;本页 <b>".$this->disnum()."</b> 条&nbsp;";
$html[2]="&nbsp;本页从 <b>{$this->start()}-{$this->end()}</b> 条&nbsp;";
$html[3]="&nbsp;<b>{$this->page}/{$this->pageNum}</b>页&nbsp;";
$html[4]=$this->firstprev();
$html[5]=$this->pageList();
$html[6]=$this->nextlast();
$html[7]=$this->goPage();

$fpage='<div style="font:12px \'\5B8B\4F53\',san-serif;">';
if(count($arr) < 1)
$arr=array(0, 1,2,3,4,5,6,7);


for($i=0; $i<count($arr); $i++)
$fpage.=$html[$arr[$i]];

$fpage.='</div>';
return $fpage;
}
}
分享到:
评论

相关推荐

    基于J2EE框架的个人博客系统项目毕业设计论文(源码和论文)

    这些都预示着我们进入了一个新的互联网阶段web 2.0,它是相对web 1.0的新的一类互联网应用的总称,是一次从核心内容到外部应用的革命[10]。这个阶段发展迅速,互联网应用趋于多样化,其中变化最大的是由web 1.0网站...

    Spring面试题

    但用这些技术构建的系统非常的繁乱,所以在此之上,我们需要一个规则、一个把这些技术组织起来的规则,这就是框架,Struts便应运而生。 基于Struts开发的应用由3类组件构成:控制器组件、模型组件、视图组件 8. ...

    JAVA面试题最全集

    给定一个C语言函数,要求实现在java类中进行调用。 45.如何获得数组的长度? 46.访问修饰符“public/private/protected/缺省的修饰符”的使用 47.用关键字final修饰一个类或者方法时,有何意义? 48.掌握类和...

    最新Java面试宝典pdf版

    16. hibernate进行多表查询每个表中各取几个字段,也就是说查询出来的结果集没有一个实体类与之对应如何解决; 123 17.介绍一下Hibernate的二级缓存 123 18、Spring 的依赖注入是什么意思? 给一个 Bean 的 message ...

    java面试宝典

    94、元素有一个cascade属性,如果希望Hibernate级联保存集合中的对象,casecade属性应该取什么值?(单选)(D) 22 95、以下哪些属于Session的方法?(A,B,C,D,F) 22 96、Hibernate工作原理及为什么要用? 22 97、...

    Java面试宝典2010版

    16. hibernate进行多表查询每个表中各取几个字段,也就是说查询出来的结果集没有一个实体类与之对应如何解决; 17.介绍一下Hibernate的二级缓存 18、Spring 的依赖注入是什么意思? 给一个 Bean 的 message 属性, ...

    Struts2+Spring+Hibernate+Ehcache+AJAX+JQuery+Oracle 框架集成用户登录注册Demo工程

    4.在服务端分页查询功能,优点:实时性:跳页才查询。数据量小:只加载当前页的记录进行显示。 5.单数据源配置(兼容Tomcat和Weblogic)。 6.Hibernate继承 HibernateDaoSupport。 7.Spring+Junit4单元测试,优点:...

    Java面试笔试资料大全

    16. hibernate进行多表查询每个表中各取几个字段,也就是说查询出来的结果集没有一个实体类与之对应如何解决; 123 17.介绍一下Hibernate的二级缓存 123 18、Spring 的依赖注入是什么意思? 给一个 Bean 的 message ...

    Java面试宝典2012版

    16. hibernate进行多表查询每个表中各取几个字段,也就是说查询出来的结果集没有一个实体类与之对应如何解决; 123 17.介绍一下Hibernate的二级缓存 123 18、Spring 的依赖注入是什么意思? 给一个 Bean 的 message...

    JAVA面试宝典2010

    16. hibernate进行多表查询每个表中各取几个字段,也就是说查询出来的结果集没有一个实体类与之对应如何解决; 123 17.介绍一下Hibernate的二级缓存 123 18、Spring 的依赖注入是什么意思? 给一个 Bean 的 message ...

    Java面试宝典-经典

    16. hibernate进行多表查询每个表中各取几个字段,也就是说查询出来的结果集没有一个实体类与之对应如何解决; 123 17.介绍一下Hibernate的二级缓存 123 18、Spring 的依赖注入是什么意思? 给一个 Bean 的 message ...

    java面试题大全(2012版)

    16. hibernate进行多表查询每个表中各取几个字段,也就是说查询出来的结果集没有一个实体类与之对应如何解决; 123 17.介绍一下Hibernate的二级缓存 123 18、Spring 的依赖注入是什么意思? 给一个 Bean 的 message ...

    Java面试宝典2012新版

    16. hibernate进行多表查询每个表中各取几个字段,也就是说查询出来的结果集没有一个实体类与之对应如何解决; 123 17.介绍一下Hibernate的二级缓存 123 18、Spring 的依赖注入是什么意思? 给一个 Bean 的 message ...

    java面试宝典2012

    16. hibernate进行多表查询每个表中各取几个字段,也就是说查询出来的结果集没有一个实体类与之对应如何解决; 135 17.介绍一下Hibernate的二级缓存 135 18、Spring 的依赖注入是什么意思? 给一个 Bean 的 message ...

    千方百计笔试题大全

    94、元素有一个cascade属性,如果希望Hibernate级联保存集合中的对象,casecade属性应该取什么值?(单选)(D) 22 95、以下哪些属于Session的方法?(A,B,C,D,F) 22 96、Hibernate工作原理及为什么要用? 22 97、...

    1000道 互联网Java架构师面试题.pdf和JAVA核心知识整理.zip

    9、通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应,请问,这个 Dao 接口的工作原理是什么?Dao 接口里的方法,参数不同时,方法能重载吗? 10、Mybatis 是如何进行分页的?分页插件的原理是什么? 11、...

    最新建站之星2.1商业破解版 带1千多套模板

    (2)用户角色的定义(先添加一个角色赋予角色下的功能并命名角色,当添加新用户时选角色,相同角色具有相同的功能。) (3)用户和角色的联系,不同用户在相同角色下具有相同的功能。 注:2.1版的角色管理功能仅限于...

    建站之星v2.1最新商业破解版 带1千多套模板

    (2)用户角色的定义(先添加一个角色赋予角色下的功能并命名角色,当添加新用户时选角色,相同角色具有相同的功能。) (3)用户和角色的联系,不同用户在相同角色下具有相同的功能。 注:2.1版的角色管理功能仅限于...

Global site tag (gtag.js) - Google Analytics