-
- 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' => '末页'
- );//在分页信息中显示内容,可以自己通过set()方法设置
- private $listNum = 5; //默认分页列表显示的个数
-
- /**
- * 构造方法,可以设置分页类的属性
- * @param int $total计算分页的总记录数
- * @param int $listRows 可选的,设置每页显示的记录数,默认25
- * @param mixed $query可选的,为向目标页面传递参数,可以是数组,也可以是查询字符串格式
- * @param bool $ord 默认是true,页面从第一页开始显示,false则从最后一页开始显示
- */ bbs.it-home.org
- public function __construct($total, $listRows=25, $query='', $ord=true){
- $this->total = $total;
- $this->listRows = $listRows;
- $this->uri = $this->getUri($query);
- $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;
- }
- }
-
- //$this->limit = 'LIMIT '.$this->setLimit();
- $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;
- }
-
- /*可以使用在对象外部,直接获取私有成员属性limit和page的值*/
- function __get($args){
- if($args == 'limit' || $args == 'page'){
- return $this->$args;
- }else{
- return null;
- }
- }
-
- /**
- * 按指定的格式输出分页
- * @param int 0-7的数字分别作为参数,用于自定义输出分页结构和调整结构的顺序,默认输出全部结构
- * @return string 分页信息内容
- */
- function fpage(){
- $arr = func_get_args();
-
- $html[0] = " 共 {$this->total} {$this->config['head']} ";
- $html[1] = " 本页".$this->disnum()."条 ";
- $html[2] = " 本页从{$this->start()} - {$this->end()}条 ";
- $html[3] = " {$this->page}/{$this->pageNum}页 ";
- $html[4] = $this->firstprev();
- $html[5] = $this->pageList();
- $html[6] = $this->nextlast();
- $html[7] = $this->goPage();
-
- $fpage = '
';
-
- if(count($arr)<1){
- $arr = array(0,1,2,3,4,5,6,7);
- }
-
- for($i=0; $i$fpage .= $html[$arr[$i]];
- }
-
- $fpage .= '
';
- return $fpage;
- }
-
- /*액세스된 현재 URL을 자동으로 얻기 위해 객체 내부에서 사용*/
- 비공개 함수 getUri($query){
- $ request_uri = $_SERVER['REQUEST_URI'];
- $url = strstr($request_uri, '?') ? $request_uri : $request_uri.'?';
-
- if(is_array($query )) {
- $url .= http_build_query($query);
- }else if($query != ''){
- $url .= '&'.trim($query, '?& ') ;
- }
-
- $arr = parse_url($url);
-
- if(isset($arr['query'])){
- parse_str($arr[ 'query '], $arrs);
- unset($arrs['page']);
- $url = $arr['path'].'?'.http_build_query($arrs);
- }
-
- if(strstr($url, '?')){
- if(substr($url, -1) != '?'){
- $url = $url.' ;
- }
- }else{
- $url .= '?';
- }
- return $url;
- }
-
- /*Private 메서드, 제한 설정 */
- 비공개 함수 setLimit(){
- if($this->page > 0){
- return ($this->page - 1)*$this->listRows ." , {$this->listRows}";
- }else{
- return 0;
- }
- }
-
- /*객체 내부에 사용되는 전용 메서드를 사용하여 현재 페이지에서 시작하는 레코드 수*/
- 비공개 함수 start(){
- if($this->total == 0){
- return 0;
- }else{
- return ($this->page-1) * $this->listRows 1;
- }
- }
-
- /*현재 페이지 끝의 레코드 수를 가져오는 데 사용됩니다. */
- 비공개 함수 end(){
- return min($this->page * $this->listRows, $this->total);
- }
-
- / *페이지에 표시된 레코드 수를 가져오는 데 사용됩니다*/
- 비공개 함수 disnum(){
- if($this->total > 0){
- return $this->end( ) - $this-> ;start() 1;
- }else{
- return 0;
- }
- }
-
- /*이전 페이지의 동작 정보를 얻기 위해 사용됩니다. 및 홈페이지*/
- 비공개 함수 firstprev(){
- if($this->page > 1){
- $str = " { $this->config['first']} ";
- $str .= "{$this->config['prev']} ";
- $str;
- }
- }
-
- 비공개 함수 pageList(){
- $linkPage = ' ';
- $pageSub = $this->page%$this->listNum;
- if($pageSub==0 && $this->page>0){
- $pageSub = $this->listNum;
- }
- /*현재 페이지 앞의 목록* /
- for($i=$pageSub -1; $i >= 1; $i--){
- $page = $this->page-$i;
- if($page >= 1){
- $linkPage .= "{$page} ";
- }
- }
-
- /*현재 페이지 정보*/
- if($this->pageNum > 1){
- $linkPage .= "{$this->page} ";
- }
-
- /*현재 뒤에 있는 목록 페이지*/
- for($i=1; $i<=$this->listNum-$pageSub; $i ){
- $page = $this->page $i;
- if ($page<=$this->pageNum){
- $linkPage .= "{$page}< /a> ";
- }else{
- break;
- }
- }
-
- $linkPage .= '';
- return $linkPage;
- }
-
- /*페이지 목록 정보 가져오기용*/
- 비공개 함수 pageListBak(){
- $linkPage = ' ';
-
- $inum = Floor ($this->listNum/2);
- /*현재 페이지 앞의 목록*/
- for($i=$inum; $i >= 1; $i--){
- $page = $this->page-$ i;
- if($page >= 1){
- $linkPage .= "{$page} ";
- }
- }
-
- /*현재 페이지 정보*/
- if($this ->pageNum > 1){
- $linkPage .= "{$this->page}< /span> ";
- }
-
- /*현재 페이지 뒤의 목록*/
- for($i=1; $i<=$inum; $i ){
- $page = $this->페이지 $i;
- if ($page<=$this->pageNum){
- $linkPage .= "{$page}< /a> ";
- }else{
- break;
- }
- }
-
- $linkPage .= '< ;/b>';
- return $linkPage;
- }
-
- /*다음 페이지와 마지막 페이지의 동작 정보 가져오기*/
- 비공개 함수 nextlast(){
- if($this->page != $this-> pageNum){
- $str = " {$this->config[ 'next']} ";
- $str .= " {$this ->config['last']} ";
- return $str;
- }
- }
-
- /*용于显示화处리表单跳转页면*/
- 비공개 함수 goPage(){
- if($this->pageNum > 1){
- return ' < ;input style="width:20px;height:17px !important;height:18px;border:1px solid #cccccc" type="text" onkeydown="javascript:if(event.keyCode==13){var 페이지=( this.value>'.$this->pageNum.')?'.$this->pageNum.':this.value;location=''.$this->uri.'page=' 페이지 '' }" value="'.$this->page.'" /> ';
- }
- }
- }
复제대码
|