게시판 페이지 관련 글입니다.
처음으로 클래스기반으로 만들어본 게시판 페이지 네비게이션 입니다.
저는 물론 사용해 보았고 현재 버그 및 오류가 없습니다.
사용시에 버그나 오류 발생 된다면 덧글 달아주세용^^
<?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);
?>
저는 물론 사용해 보았고 현재 버그 및 오류가 없습니다.
사용시에 버그나 오류 발생 된다면 덧글 달아주세용^^
<?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);
?>
게시글 목록
| 번호 | 제목 |
|---|---|
| 28080 | |
| 7612 | |
| 7598 | |
| 7595 | |
| 19842 | |
| 28079 | |
| 19840 | |
| 7593 | |
| 28076 | |
| 7590 | |
| 28072 | |
| 28065 | |
| 19836 |
jQuery
슬라이드 스크립트 도움 부탁드립니다.
3
|
| 7586 | |
| 28058 | |
| 7573 | |
| 31754 |
부트스트랩
data-toggle 체크박스 활용
|
| 7552 | |
| 28057 | |
| 30993 |
반응형
각 해상도별 테스트.
8
|
| 28052 | |
| 7546 | |
| 7544 | |
| 7538 | |
| 7519 | |
| 30992 |
HTML
결제모듈과 구글웹사이트 번역 엘리먼트
|
| 19834 |
웹서버
리눅스 시스템 백업 복구툴
1
|
| 7517 | |
| 7512 | |
| 7511 | |
| 19832 | |
| 19820 | |
| 7509 | |
| 24658 | |
| 7508 | |
| 7507 | |
| 19818 | |
| 30990 |
HTML
팁] 모바일에서 문자보내기
1
|
| 7506 | |
| 7505 | |
| 7498 | |
| 7492 | |
| 28051 | |
| 7481 | |
| 30988 |
반응형
짧고 굵은거
1
|
| 19813 | |
| 19812 | |
| 7477 | |
| 7476 | |
| 7471 | |
| 7467 | |
| 19810 | |
| 7464 | |
| 19809 | |
| 7463 | |
| 7457 | |
| 30980 | |
| 7450 | |
| 28043 | |
| 7447 | |
| 7440 | |
| 28040 | |
| 7438 | |
| 7430 | |
| 7427 | |
| 7423 | |
| 7414 | |
| 7408 | |
| 7405 | |
| 7401 | |
| 7400 | |
| 19808 | |
| 7398 | |
| 7393 | |
| 7389 | |
| 19805 |
JavaScript
Ajax 로 받은 Json 값을 View 형식에 맞춰 표현
2
|
| 7382 | |
| 7379 | |
| 7378 | |
| 7363 | |
| 7361 | |
| 7356 | |
| 19804 | |
| 7355 | |
| 7352 | |
| 19786 | |
| 7342 | |
| 7336 | |
| 7332 | |
| 19783 | |
| 7328 | |
| 7325 | |
| 7324 | |
| 28036 | |
| 19782 | |
| 7321 | |
| 26574 | |
| 7314 | |
| 7312 | |
| 19781 |
MySQL
MYSQL 쿼리순서, 부하여부 질문드려요
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기