Develop
2003.04.23 11:05
[php] 초간단 게시판 페이지 분할 알고리즘
조회 수 8752 댓글 0
페이지 넘기기 알고리즘을 알려드리겠습니다.
다소 어려운 부분이 있을것입니다.
따로 정의 되어 있어야 하는 변수를 설명 해드리겠습니다.
------------------------------------------------------
$page : 페이지
$total : 총 게시물수
$limite : 한페이지당 출력될 게시물수
$page_num : 한 페이지당 출력될 링크수
------------------------------------------------------
## 한 화면에 표시될 게시물 뽑아오는 알고리즘
if(!$page) $page=1; // 페이지가 없으면 1로 정한다
$total_page = intval(($total-1) / $limite)+1; // 총 페이지수를 구해온다
$first = ($page-1)*$limite; // 뽑아올 게시물 [처음]
$last = $limite; // 뽑아올 게시물 [끝]
// 뽑아올 게시물[끝] : 총 게시물 수가 한페이지당 출력될 게시물수보다 적으면 총 게시
물수를 뽑아올 게시물[끝] 으로 정한다
if($total < $last) $last = $total;
// 뽑아올 게시물 [처음]~뽑아올 게시물 [끝] 구한값으로 한페이지에 글을 뽑아 온다
$limit = "limit $first,$last";
## 게시물을 출력한다(생략) #####
## 페이지 링크 구하는 알고리즘
// 한 화면에 출력될 페이지 링크가 3개라고 가정 하면 현재 페이지가 4라면 4,5,6 이라
는 링크만 출력되게 한다
// 4가 나오는식
$first_page = intval(($page-1)/$page_num+1)*$page_num-($page_num-1);
// 6을 구하는식
$last_page = $first_page+($page_num-1);
if($last_page > $total_page) $last_page = $total_page;
// [이전] 버튼 링크
$prev = $first_page-1;
if($page > $page_num) echo"[이전] ";
// [4] [5] [6]
// 페이지 링크 출력 : 4와 6을 구했으니 여기서는 4~6까지를 for문으로 출력
for($i = $first_page; $i <= $last_page; $i++)
{
if($page == $i) echo"[$i] "; // 출력될 번호가 현재 페이지랑 같다면 진하게
else echo"[$i]";
}
// [다음] 버튼 출력
$next = $last_page+1;
if($next <= $total_page) echo"[다음]";
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
517 | Develop | [c] 이진 탐색 두 가지 코드 (재귀/반복) | hooni | 2015.06.26 | 961 |
516 | Develop | [c] 이진트리(binary tree) 샘플소스 (삽입, 삭제, 운행) | hooni | 2003.04.23 | 7835 |
515 | Develop | [c] 이진트리(binary tree)의 운행.. | hooni | 2003.04.23 | 8297 |
514 | Develop | [c] 이진트리(binary tree)의 특성 | hooni | 2003.04.23 | 9633 |
513 | Develop | [c] 이진트리/트리 순회법 코드(전위/중위/후위) 5 | hooni | 2015.07.02 | 21060 |
512 | Develop | [c] 자료구조 그래프(graph) 소스코드 - 확인해볼 것.. | hooni | 2013.04.23 | 8009 |
511 | Develop | [c] 재미있는 코딩.. | hooni | 2003.04.23 | 21402 |
510 | Develop | [c] 전위 표기법으로 연산 예제.. | hooni | 2013.04.23 | 9314 |
509 | Develop | [c] 정사각배열의 서브 배열의 최대 값 구하기 | hooni | 2003.04.23 | 7041 |
508 | Develop | [c] 정수를 2진수로 변환 (재귀,비트연산) | hooni | 2003.04.23 | 7604 |
507 | Develop | [c] 지나가는 패킷 잡기 | hooni | 2003.04.23 | 8863 |
506 | Develop | [c] 지폰(gphone) 소스.. 수정(암호화) | hooni | 2013.04.23 | 7442 |