COMING SOON 🚀

게시판 페이지 관련 글입니다.

· 12년 전 · 2961
처음으로 클래스기반으로 만들어본 게시판 페이지 네비게이션 입니다.
저는 물론 사용해 보았고 현재 버그 및 오류가 없습니다.
사용시에 버그나 오류 발생 된다면 덧글 달아주세용^^
<?php
/**
* Class Name : paging
* Description : 게시판의 페이지 네비게이션을 리턴 합니다.
* Modification Information
*
* @수정일: 2012-05-18
* @작성/수정자: 이강민
* @수정내용: 최초 작성
*
* @author 이강민
* @since 2012-05-18
* @version 1.0
*/

class paging
{
///////////////////// 사용자 정의 변수 선언부 //////////////////////

public $recordPerPage; //페이지당 보여질 레코드 수
public $pagePerBlock; //블럭당 보여질 페이지 링크 수
public $prevBlockBtn; //이전 블럭 이동 이미지 경로
public $nextBlockBtn; //다음 블럭 이동 이미지 경로

///////////////////// 시스템 변수 선언부 //////////////////////////

protected $totalRecord; //전체 레코드 수를 담을 변수
protected $totalNumOfPage; // 전체 페이지 수
protected $totalNumOfBlock; //전체 블럭 수
protected $currentBlock; //현재 블럭 위치 값 담을 변수
protected $searchString = ""; //검색 쿼리
protected $pointer; //레코드 포인터 위치 값 담을 변수
protected $number; //게시물 인덱스 번호 담을 변수

protected $startPage=0; //시작 페이지 번호 담을 변수
protected $endPage=0; //끝 페이지 번호 담을 변수
protected $isPrev=false; //이전 페이지 이동, 초기값 셋팅
protected $isNext=false; //다음 페이지 이동, 초기값 셋팅
protected $goPrevPage=0;
protected $goNextPage=0;

protected $thePage = NULL;

/**
* 게시판 레코드를 가져올 레코드의 위치를 리턴

* @param page - 페이지 값

* @return $this->pointer - 레코드 위치 리턴 함수
*/
public function getPointer($page) {
return $this->pointer = ($page-1) * $this->recordPerPage;
}

/**
* 페이지 번호 생성 함수

* @param
$totalNumOfPage - 전체 페이지 수
$currentBlock - 현재 블럭 위치값
$pagePerBlock - 블럭당 보여질 링크 수
$page - 페이지 값
$searchString - 검색 쿼리스트링

* @return $this->thePage - 페이지 네비게이션 넘버
*/
protected function getPageNumber($totalNumOfPage, $currentBlock, $pagePerBlock, $page, $searchString) {

$this->startPage = ($currentBlock - 1) * $pagePerBlock + 1; //시작페이지
$this->endPage = min($totalNumOfPage, $currentBlock * $pagePerBlock); // 마지막 페이지

if($currentBlock == 1) {
$this->isNext = false;
$this->isPrev = false;
}

if($this->endPage < $totalNumOfPage) { $this->isNext= true;} //다음 블럭 허용

if($currentBlock > 1) { $this->isPrev = true; } //이전 블럭 허용


// 이전 블럭 이동 체크
if($this->isPrev)
{
$this->goPrevPage = $this->startPage - $this->pagePerBlock();
$this->thePage  = "<a href=\"".$this->_PHP_SELF."?page=".$this->goPrevPage."&".$searchString."\">
<img src=\"/images/bbs/left_btn.gif\" border=\"0\" title=\"이전 10 페이지\" /></a> ";
}
else
{
$this->thePage  = "<img src=\"/images/bbs/left_btn.gif\" border=\"0\" title=\"이전 10 페이지\" /> ";
}


for($p=$this->startPage;$p<=$this->endPage;$p++) {
if($p!=$page)
{
$this->thePage .= " <a href=\"$_PHP_SELF?page=$p&$searchString\">$p</a> ";
}
else
{
$this->thePage .= " <b>$p</b> ";
}
}



// 다음 블럭 이동 체크
if($this->isNext)
{
$this->goNextPage = $this->startPage + $pagePerBlock;
$this->thePage .= "<a href=\"".$this->_PHP_SELF."?page=".$this->goNextPage."&".$searchString."\">
<img src=\"/images/bbs/right_btn.gif\" title=\"다음 10 페이지\" /></a>";
}
else
{
$this->thePage .=  " <img src=\"/images/bbs/right_btn.gif\" title=\"다음 10 페이지\" />";
}

return $this->thePage;

}

/**
* 페이지 번호 생성을 위한 계산식

* @param
$total - 전체 페이지 수
$page - 파라미터로 넘어온 페이지 값
$searchString - 검색 쿼리스트링

* @return $this->getPageNumber 함수를 리턴 합니다.
*/
public function BoundSet($total, $page, $searchString='')
{
$this->totalRecord = $total; //전체 페이지 수

//전체 페이지 수, 전체 블럭 수 얻는다.
$this->totalNumOfPage = ceil($this->totalRecord / $this->recordPerPage);
$this->totalNumOfBlock = ceil($this->totalNumOfPage / $this->pagePerBlock);

//현재 블럭 위치 값 확인
$this->currentBlock = ceil($page / $this->pagePerBlock);

$this->pointer = $this->getPointer($page); //레코드 포인터 위치 값 가져오기.
$this->number = $this->totalRecord - $this->pointer; //인덱스 번호

## 페이지 네비게이션 로드
## Parameter Comment: 전체 페이지 수, 현재 블럭 위치값, 블럭당 보여질 링크 수, 페이지 값, 검색 쿼리스트링
return  $this->getPageNumber($this->totalNumOfPage, $this->currentBlock, $this->pagePerBlock, $page, $searchString);


}
}

//사용방법
$page = $_REQUEST['page'];

if(!$page) { $page = 1; } //페이지를 확인합니다.

$paging = new paging; //클래스 생성
$paging->recordPerPage = 10; //페이지당 보여질 레코드 수 지정
$paging->pagePerBlock = 10; //한 블럭당 보여질 링크 수 지정
$paging->getPointer($page); //본문 레코드를 가져올 레코드 포인터를 리턴

/*
본문 list 가져올 시 sql 작성법
select * from bbs limit $paging->getPointer($page), 페이지당 보여질 레코드 수
*/

/**
* 게시판 페이지 네비게이션을 가져옵니다.
* @param
$total - 검색되어진 전체 레코드 수
$page - 파라미터로 넘어온 page 값
$search - 검색 쿼리스트링
*/
$total = 199;
echo $paging->BoundSet($total, $page, $search);
?>

첨부파일

게시판페이징.txt (5.2 KB) 7회 2013-11-18 13:11
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
12년 전 조회 1,290
12년 전 조회 2,005
12년 전 조회 2,318
12년 전 조회 1,344
12년 전 조회 1,263
12년 전 조회 2,249
12년 전 조회 1,344
12년 전 조회 1,912
12년 전 조회 1,746
12년 전 조회 2,148
12년 전 조회 2,208
12년 전 조회 6,930
12년 전 조회 2,262
12년 전 조회 1,466
12년 전 조회 1,319
12년 전 조회 1,383
12년 전 조회 1,443
12년 전 조회 1,702
12년 전 조회 2,334
12년 전 조회 1,824
12년 전 조회 2,092
12년 전 조회 1,331
12년 전 조회 1,456
12년 전 조회 3,418
12년 전 조회 2,501
12년 전 조회 2,255
12년 전 조회 4,040
12년 전 조회 1,444
12년 전 조회 3,287
12년 전 조회 2,860
12년 전 조회 2,724
12년 전 조회 2,761
12년 전 조회 1,733
12년 전 조회 2,274
12년 전 조회 2,282
12년 전 조회 1,713
12년 전 조회 4,177
12년 전 조회 1,408
12년 전 조회 1,910
12년 전 조회 2,317
12년 전 조회 2,784
12년 전 조회 1,665
12년 전 조회 2,348
12년 전 조회 1,739
12년 전 조회 3,283
12년 전 조회 1,763
12년 전 조회 1,594
12년 전 조회 1,848
12년 전 조회 3,426
12년 전 조회 2,962
12년 전 조회 5,268
12년 전 조회 2,545
12년 전 조회 2,997
12년 전 조회 2,378
12년 전 조회 2,330
12년 전 조회 1,846
12년 전 조회 1,887
12년 전 조회 2,761
12년 전 조회 1,937
12년 전 조회 1,648
12년 전 조회 2,222
12년 전 조회 2,542
12년 전 조회 1,814
12년 전 조회 1,936
12년 전 조회 2,146
12년 전 조회 2,931
12년 전 조회 1,812
12년 전 조회 2,090
12년 전 조회 4,046
12년 전 조회 1,808
12년 전 조회 1,720
12년 전 조회 1,679
12년 전 조회 2,391
12년 전 조회 2,217
12년 전 조회 4,910
12년 전 조회 2,036
12년 전 조회 1,900
12년 전 조회 1,788
12년 전 조회 1,665
12년 전 조회 2,210
12년 전 조회 1,915
12년 전 조회 2,077
12년 전 조회 1,590
12년 전 조회 1,631
12년 전 조회 1,777
12년 전 조회 2,172
12년 전 조회 2,139
12년 전 조회 1,609
12년 전 조회 2,020
12년 전 조회 5,839
12년 전 조회 3,807
12년 전 조회 2,094
12년 전 조회 1,840
12년 전 조회 2,645
12년 전 조회 1,988
12년 전 조회 6,379
12년 전 조회 7,436
12년 전 조회 2,298
12년 전 조회 2,062
12년 전 조회 1,692