묻고답하기

php로 게시판을 만들고 있습니다.

 

bbs_list.php에 한 페이지 당 표시될 게시물 갯수($perpage)를 10으로 잡았습니다.

bbs_function.php는 목록 뿌리기, 페이지 계산 등을 담당하는 파일입니다.

 

그런데 게시판의 게시물이 10개만 되면 맨 첫번째 글만 출력됩니다.

예를 들어 아래와 같이 목록에 나옵니다.

해당 게시판의 데이터베이스입니다. 총 10개입니다.

 

 

 

그런데 글 한개만 더 써서 11개를 만들면 정상적으로 출력됩니다.

아래와 같이 출력됩니다.

 

 

 

 

 

 

11개일경우 해당 게시판 데이터베이스입니다.

 

 

 

bbs_list.php 소스입니다.

<?
/*--------------------------
 filename : list.php3
--------------------------*/
require "bbs_function.php";

$perpage = "10";  // 한페이지당 10개 뿌리기

if ($page == "") {
  $page = 1;
}

$tlpn = get_pagenum();

$result = arti_list($tlpn, $perpage);

echo ("
// 맨 윗줄의 번호, 제목 등을 표시하는 부분 (편의상 생략)
");

$i = 0;
while($list = mysql_fetch_array($result)) {

  echo "
echo ("
// 게시물 번호, 제목, 작성자 등을 반복적으로 출력하는 부분 (편의상 생략)
";
}

echo "<br><center><font size=\"1\">"; movepage ($page, 2); echo "</font></center>";
?>

 

 

bbs_function.php 소스입니다.

<?
/*--------------------------
 filename : function.php3
--------------------------*/
function arti_list($tlpn, $perpage) {
 include "account.php";

  global $board, $page; // 수정

  $result = lpp($tlpn, $perpage, $page); // 추가

return $result;
}

function get_pagenum() {
  global $board, $perpage;

 include "account.php";

  $result = mysql_query("SELECT COUNT(*) FROM $board",$dbconn);
  $tlpn[num] = mysql_result($result, 0, "COUNT(*)");

  if($tlpn[num] % $perpage) {
    $tlpn[page]= intval($tlpn[num] / $perpage) + 1;
  }
  else {
    $tlpn[page]= $tlpn[num] / $perpage;
  }

  return $tlpn;
}

function lpp($tlpn, $perpage, $page) {
  global $board;

 include "account.php";

  if(($tlpn[page] > $page) && ($page > 1)) {
    $lastpagelist = $tlpn[num] - (($page - 1) * $perpage);
 
    $result = mysql_query("SELECT * FROM $board WHERE
      idx <= $lastpagelist
      ORDER BY idx DESC LIMIT $perpage", $dbconn);
  }
 
  elseif ($tlpn[page] == $page) { // 맨 마지막 페이지라면..
    if ($tlpn[num] % $perpage) {
      $lastpagelist = $tlpn[num] % $perpage;
    }
    else {
      $lastpagelist = $page;
    }
 
    $result = mysql_query("SELECT * FROM $board
      WHERE idx <= $lastpagelist
      ORDER BY idx DESC", $dbconn);
  }
 
  elseif ($page == "1") { // 첫 페이지라면..
    $result = mysql_query("SELECT * FROM $board
    ORDER BY idx DESC LIMIT $perpage", $dbconn);
  }
 
  else {
    echo "잘못된 페이지";
    exit;
  }
  return $result;
 
}

function movepage($page, $numpage) {
  global $board, $tlpn;
 
  if ($page == 1) { // 맨 처음 페이지
 echo "<b>[Top]</b> ";
  }
  else {
    echo "<a href=\"bbs_list.php?board=$board&page=1\">[Top]</a> ";
  } // 맨 처음 페이지 끝
   
  $topnear = $page - $numpage;
  $lastnear = $page + $numpage;
 
  if ($topnear <= 1) {
    $pres = 1;
    if ($tlpn[page] <= ($numpage * 2 + 1)) {
      $nexs = $tlpn[page];
    }
    else {
      $nexs = $numpage * 2 + 1;
    }
  }
  elseif (($page == $tlpn[page]) && ($tlpn[page] <= ($numpage * 2))) {
    $pres = 1;
    $nexs = $tlpn[page];
  }
  elseif ($lastnear >= $tlpn[page]) {
    $pres = $tlpn[page] - ($numpage * 2);
    $nexs = $tlpn[page];
  }
  else {
    $pres = $topnear;
    $nexs = $lastnear;
  }
 
  // 이동할 페이지의 가장 처음이 1 페이지보다 클 경우 생략 기호 출력
  if ($pres > 1) {
    echo "<b> ... </b>";
  } 
 
  for($i=$pres; $i <= $nexs; $i++) { // 중간
    if ($i == $page) {
      echo "<b>[$i]</b> ";
    }
    else {
      echo "<a href=\"bbs_list.php?board=$board&page=$i\">[$i]</a> ";
    }
  } // 중간

  // 이동할 페이지의 가장 끝이 마지막 페이지보다 작을 경우 생략 기호 출력
  if ($nexs < $tlpn[page]) {
    echo "<b> ... </b>";
  } 
  
  if ($page == $tlpn[page]) { // 맨 끝 페이지
    echo "<b>[Last]</b> ";
  }
  else {
    echo "
  <a href=\"bbs_list.php?board=$board&page=$tlpn[page]\">[Last]</a> ";
  } // 맨 끝 페이지 완료
}
?>

 

 

글쓴이 제목 최종 글
XE 공지 글 쓰기,삭제 운영방식 변경 공지 [16] 2019.03.05 by 남기남
소우리 방명록에 댓글 쓸 수 없나요?? [2] file 2008.12.22 by N0ah
StyleD 업그레이드해야되는데 ㅠㅠ... 그외 간단한 설문... [1] 2008.12.22 by 넨네
소우리 스킨제작용 각국언어로 번역좀.. 부탁드려요  
ddddffdfd 글 목록에서 제목 배치 바꾸는 방법. [3] 2008.12.22 by ddddffdfd
php1986 안녕하세요 초보인데요... 총 회원수 / 오늘 가입 / 오늘 들어온회원 [1] 2008.12.22 by 띵야
PinkWink 혹시 글쓰기 하다가 익스플로러가 멈추는 분 있으신가요?  
이미용 제로보드 4를 쓰고있는데... [1] 2008.12.22 by 느까끼
푸키푸키푸캬 XE를 이용하여 홈페이지 만들기 중, 레이아웃 관련 질문드립니다. [2] 2008.12.22 by 애치티
zeon 페이지 수정, 위젯 콘트롤 아이콘 에러... ㅠ.ㅠ [1] file 2008.12.22 by 느까끼
서원준219 메인페이지 만들었는데요. 인터넷 적용하는 방법좀 알려주십시오. [1] 2008.12.22 by 느까끼
울보아기 제로4처럼 백업하는 방법 부탁드려요 [1] 2008.12.22 by 느까끼
카운터 기본카운터와 이미지카운터가 제대로 출력안되요ㅠ [1] file 2008.12.22 by 느까끼
ㅎㅎ 컴포넌트가 제대로 안떠요 [4] file 2008.12.22 by ㅎㅎ
모르는게넘많아 XE 1.1.2 전체 파일 다운로드 되는분? [2] 2008.12.22 by 모르는게넘많아
모르는게넘많아 1.1.2 업후에 로고 사라지는 현상  
yong XE_blog 레이아웃에서 위젯 다 날리고 내용만 전체 표시할 수 있는 방법은? [3] 2008.12.22 by yong
난욕먹어야돼~ 욕 먹어도 싸지...Zb4에서... [6] 2008.12.22 by oops
바다사내 일본,홍콩,중국 서버업체 질문드려요  
심유경 관리자가 모르는 회원가입... 해킹일까요? [3] 2008.12.22 by 무대포2
궁금 한줄게시판 위젯의 글쓴이 공간 크기를 늘리고 싶어요 [2] file 2008.12.22 by 감사