封装好的分页类

原创 2016年05月31日 11:27:51

提示:仅供参考

page.class.php

<meta charset="utf8">
<style>
	a {
		display:inline-block;
		border:1px solid #ccc;
		text-decoration:none;
		padding:5px;
		margin:20px 3px;
		color:#333;
	}
	.apage{
		background:#ccc;
	}
	.disable{
		border:1px solid #ccc;
		color:#ccc;
	}
</style>

<?php
require "mysql.class.php";
class page {
	private $total;
	private $number=10;
	private $pagecount;
	public $limit;
	private $url;
	private $page;
    function __construct($total,$number,$url) {
    	$this->total=$total;
    	$this->number=$number;
    	$this->pagecount=ceil($this->total/$this->number);
    	$this->getpage();
    	$this->url=$url;
		$this->limit="limit ".$this->setlimit();
    }
    private function getpage(){
    	$this->page=(isset($_GET['page'])&&!empty($_GET['page']))?$_GET['page']:1;
		if(preg_match('/\D/',$this->page)){
			$this->page=1;
		}
		if($this->page<=0){
			$this->page=1;
		}
		if($this->page > $this->pagecount){
			$this->page=$this->pagecount;
		}
    }
    private function setlimit(){
    	$start=($this->page-1)*$this->number;
    	return ($start.','.$this->number);
    }

    private function setnumber($num){
    	$str="";
		if($this->pagecount<=$num){
			for($i=1;$i<=$this->pagecount;$i++){
				if($this->page==$i){
					$str.= "<a href='".$this->url."?page=".$i."' class='apage'>".$i."</a>";
				}else{
					$str.= "<a href='".$this->url."?page=".$i."'>".$i."</a>";
					//echo "<a href='demo1.php?page=".$i ."&number=".$number."'>".$i."</a>";
				}
			}
		}else{
			if($this->page<=ceil($num/2)){
				for($i=1;$i<=$num;$i++){
					//给当前页加一个灰色的背景
					if($this->page==$i){
						$str.= "<a href='".$this->url."?page=".$i."' class='apage'>".$i."</a>";
					}else{
						$str.= "<a href='".$this->url."?page=".$i."'>".$i."</a>";
					}
				}
			}elseif($this->page>=$this->pagecount-floor($num/2)){
				//当前页在后3页时,能实现的效果是,点击后三页的时候,分页不会动
				for($i=$this->pagecount-$num-1;$i<=$this->pagecount;$i++){
					//给当前页加一个灰色的背景
					if($this->page==$i){
						$str.= "<a href='".$this->url."?page=".$i."' class='apage'>".$i."</a>";
					}else{
						$str.= "<a href='".$this->url."?page=".$i."'>".$i."</a>";
					}
				}
			}else{
				//将当前页放在中间页数时
				for($i=$this->page-floor($num/2);$i<=$this->page+floor($num/2);$i++){
					if($this->page==$i){
						$str.= "<a href='".$this->url."?page=".$i."' class='apage'>".$i."</a>";
					}else{
						$str.= "<a href='".$this->url."?page=".$i."'>".$i."</a>";
					}
				}
			}
		}
		return $str;
    }
    public function fpage($number=false,$num=5){
        $str="";
        if($this->page==1){
            $str.="<a href='javascript:void(0);' class='disable'>首页</a>";
            $str.="<a href='javascript:void(0);' class='disable'>上一页</a>";
        }else{
            $str.="<a href='".$this->url."?page=1'>首页</a>";
            $str.="<a href='".$this->url."?page=".($this->page-1)."'>上一页</a>";
        }
        if($number){
            $str.=$this->setnumber($num);
        }
        if($this->page==$this->pagecount){
            $str.="<a href='javascript:void(0);' class='disable'>下一页</a>";
            $str.="<a href='javascript:void(0);' class='disable'>尾页</a>";
        }else{
            $str.="<a href='".$this->url."?page=".($this->page+1)."'>下一页</a>";
            $str.="<a href='".$this->url."?page=".$this->pagecount."'>尾页</a>";
        }
        return $str;
    }
}

2.显示出来

<?php
include "libs/Smarty.class.php";
include "page.class.php";
$smarty=new Smarty();
//include "mysql.class.php";
//连接数据库
$mysql=new Mysql('127.0.0.1','root','root','1408phpe');
//查询总条数
$total=$mysql->counts("select * from exam8 ");
//$sql="select * from exam8 ";
$page=new page($total,2,'show1.php');
$sql="select * from exam8 $page->limit";
$a=$mysql->select_all($sql);
$smarty->assign('arr',$a);
$smarty->display('show1.tpl');
echo"<p align='left'>".$page->fpage(true)."</p>";


版权声明:本文为郝云原创文章,未经郝云允许不得转载。

相关文章推荐

【菜鸟学Java】3:封装一个分页类PageBean

背景介绍:         在做网上商城的项目时,有一个非常高频的功能需求,那就是做Web前端开发都知道的分页显示数据。当然要实现这个功能方法是非常多的,在我之前的做的项目接口管理系统中,使用的实现...

C# SQL 分页封装

using System.Collections.Generic; using System.Linq; using System.Data.SqlClient; using System.Da...

简单的分页封装(一)

分页对象接口: public interface Paginable { /** * 总记录数 * * @return */ public int getTotalCount(...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

php封装分页类+分页实例

分页类的封装如下: page.php
  • C_jian
  • C_jian
  • 2016年10月27日 13:21
  • 1957

php四个常用类封装

这4个常用类分别是Mysql类、分页类、缩略图类、上传类

PHP,分页函数封装成类

最近因为项目用到php。查看文档,基本看懂怎么用,怎么说呢,很多特性或者习惯,习惯了python,就觉得php很多不可理喻之处。当然,可能我对于php的造化尚浅吧。 写了一个分页函数,然后封装成类,...
  • rsj217
  • rsj217
  • 2012年08月25日 21:57
  • 2275

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

spring+springMVC+MyBatis 分页功能代码封装

页面效果图展示: 分页工具类:Pagination package com.wlsq.kso.util; import java.io.Serializable; import ja...

ASP.NET MVC分页库(一)【基础类库】

实体,接口,实现类 public interface IPagedList { int PageCount { get; } int TotalItem...
  • WuLex
  • WuLex
  • 2017年04月09日 00:09
  • 580
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:封装好的分页类
举报原因:
原因补充:

(最多只允许输入30个字)