PHP面向对象(OOP)----分页类

同验证码类,分页也是在个人博客,论坛等网站中不可缺少的方式,通过分页可以在一个界面展示固定条数的数据,而不至于将所有数据全部罗列到一起,实现分页的原理其实就是对数据库查询输出加了一个limit限制,接下来我们就开始准备今天分页类的逻辑

逻辑准备

实现分页,我们需要获取准备以下属性和方法

属性{
  	数据总条数
    每一页显示的条数
    计算出总页数
    获取当前是第几页
    显示上一页
    显示下一页
    显示首页
    显示尾页
    每一页的url
    数据限制limit
}
方法{
  构造函数
    计算总页数
    获取当前页
    获取上一页
    获取下一页
    获取首页
    获取尾页
    获取当前页面url
    获取上一页url
    获取下一页url
    获取首页url
    获取尾页irl
    生成limit记录
    重新生成url地址
    显示分页链接,显示分页情况
}

根据上面的逻辑,下一步将文字转换为代码

首先,我们先声明一个Page类,按照逻辑进行属性声明,并且进行初始化

class Page
{
 	//记录总条数
	protected $total;
	//每页显示几条
	protected $nums;
	//总页数
	protected $totalPages;
	//当前页码
	protected $currentPage;
	//上一页页码
	protected $prevPage;
	//下一页页码
	protected $nextPage;
	//首页页码
	protected $firstPage;
	//尾页页码
	protected $endPage;
	//url
	protected $url;
	//limit,传到数据库的limit
	protected $limit;
  
  	//构造函数,初始化
	public function __construct($total, $nums)
	{
		$this->total = $total;
		$this->nums = $nums;

		$this->totalPages = $this->getTotalPages();
		$this->currentPage = $this->getCurrentPage();

		$this->getPrevPage();
		$this->getNextPage();
		$this->getFirstPage();
		$this->getEndPage();
		$this->getUrl();

	}
}

接下来我们开始完善方法

  • 计算总页数
protected funciton getTotalPages()
  {
    return ceil($this->total / $this->$nums);
  }
  • 获取当前页码
protected function getCurentPage()
{
  //判断如果存在page参数并且page大于0,返回实际值,否则返回1
  if(isset($_GET['page']) && intval($_GET['page']) > 0)
    {
      $this->currentPage = intval($_GET['page']);
    } else {
      $this->currentPage = 1;
    }
  return $this->currentPage;
}
  • 获取上一页
protected function getPrevPage()
  {
    $this->prevPage = $this->currentPage - 1;
  	if($this->prevPage < 1)
      {
        $this->prevPage = 1;
      }
  	return $this->prevPage;
  }
  • 获取下一页
protected function getNextPage()
  {
    $this->nextPage = $this->currentPage + 1;
 	return $this->nextPage;
  }
  • 获取首页
protected function getFirstPage()
  {
    $this->firstPage = 1;
  	return $this->firstPage;
  }
  • 获取尾页
protected function getEndPage()
  {
    $this->endPage = $this->totalPages;
  	return $this->endPage;
  }

接下来开始拼接每个页码的url

  • 获取当前页的url
protected function getCurrentUrl()
  {
    return $this->url.'$page='.$this->currentPage;
  }
  • 获取前一页的url
protected function getPrevUrl()
  {
    return $this->url.'&page='.$this->prevPage;
  }
  • 获取下一页的url
protected function getNextUrl()
  {
    return $this->url.'&page='.$this->nextPage;
  }
  • 获取首页的url
protected function getFirstUrl()
  {
    return $this->url.'&page='.$this->firstPage;
  }
  • 获取尾页的url
protected function getEndUrl()
  {
    return $this->url.'&page='.$this->endPage;
  }

生成limit记录

public function limit()
  {
    return ($this->currentPage - 1) * $this->nums.','.$this->nums;
  }

生成url地址

public function getUrl()
  {
  	//获取当前页面的文件位置
    $url = $_SERVER['REQUEST_URI'];
  	//将url参数解析成数组
  	$parse = parse_url($url);
  	//获得域名地址
  	$path  = $parse['path'];
  	//获取参数
  	$query = isset($parse['query']) ? $parse['query'] : false;
  	//如果有参数,把page这个参数先给干掉,因为我们要重新拼接
  	if($query)
      {
        parse_str($query,$query);
      	//干掉page参数,保留其他参数
        unset($query['page']);
      	//http_build_query拼将参数拼接成请求
        $uri = $parse['path'].'?'.http_build_query($query);
      } else {
        $uri = rtrim($parse['path'],'?').'?';
      }
  
  	//智能识别https和http协议和端口号
  $protocal = (isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == 443) ? 'https://' : 'http://';
  switch ($_SERVER['SERVER_PORT']) {
    case 80:
    case 443:
      $uri = $protocal.$_SERVER['SERVER_NAME'].$uri;
      break;
    default:
      $uri = $protocal.$_SERVER['SERVER_NAME'].':'.$_SERVER['SERVER_PORT'].$uri;
      break;
  }
  $this->url = $uri;
}

到此所有的逻辑方面都已经处理完啦,接下来的render()函数用来显示分页的链接

public function render()
  {
    return array(
    		['first' => $this->getFirstUrl()],
      		['prev'  => $this->getPrevUrl()],
      		['current' => $this->getCurrentUrl()],
      		['next'  => $this->getNextUrl()],
      		['end'   => $this->getEndUrl()]
    );
  }

哦也,就这么愉快的结束啦

使用方法如下

//new一个对象
$page = new Page(102,10);
//打印出来上页/下页/首页/尾页……的url
var_dump($page->render());

后记


$url = http://www.zhyunfe.com/OOP/Page.class.php?page=1
parse_url($url):将url的文件路径和参数分开并保存到数组中
  
 ..........................................
 .  array (size=2)
 .	'path' => string '/OOP/Page.class.php' (length=36)
 .	'query' => string 'page=1' (length=6)
 ..........................................
  					...
  
$query = "page=1&num=2&sex=男"
parse_str($query,$query):将带参数的字符串解析成数组
 ..........................................
 . array
 . 	'page' => 1
 .	'num'  => 2
 .	'sex'  => '男'
 ..........................................
  					...
  
 $query = ['num'=>1,'sex'=>'男']
  
 http_build_query($query):使用给出的关联(或下标)数组生成一个经过 URL-encode 的请求字符串。 
 
 .........................................
 . string
 .	"num=1&&sex='男'"
 .........................................
  
  					...
  
  $_SERVER['SERVER_PORT'] 获取端口号
  $_SERVER['SERVER_NAME'] 当前运行脚本所在的服务器的主机名。如果脚本运行于虚拟主机中,该名称是由那个虚拟主机所设置的值决定
  
posted @ 2017-02-10 17:05  赵公子  阅读(1706)  评论(0编辑  收藏  举报