페이지네이션에서 오류(예. 2페이지를 눌러도 1페이지의 게시물이 보입니다..)

매출이 오르면 내리는 수수료! 지금 수수료센터에서 전자결제(PG)수수료 비교견적 신청해 보세요!
페이지네이션에서 오류(예. 2페이지를 눌러도 1페이지의 게시물이 보입니다..)

QA

페이지네이션에서 오류(예. 2페이지를 눌러도 1페이지의 게시물이 보입니다..)

본문

<?php

if (!defined('_GNUBOARD_')) exit;

 

// 인기글 추출

function latest_popular($rows=10, $subject_len=40, $term='', $options='', $page=1)

{

    global $g5;

 

    switch($term){

        case '일간':

            $term_time = date("Y-m-d H:i:s", G5_SERVER_TIME-3600*24);

            break;

        case '주간':

            $term_time = date("Y-m-d H:i:s", G5_SERVER_TIME-3600*24*7);

            break;

        default:

            $term_time = date("Y-m-d H:i:s", G5_SERVER_TIME-3600*24);

            break;

    }

 

    $list = array();

    $offset = ($page - 1) * $rows;

 

    // 전체 게시판에서 인기글 추출

    $sql_between = " a.bn_datetime between '$term_time' and '".G5_TIME_YMDHIS."' ";

    $sql_common = " from {$g5['board_new_table']} a, {$g5['board_table']} b

                    where a.bo_table = b.bo_table and b.bo_use_search = 1

                    and a.wr_id = a.wr_parent and {$sql_between} ";

    $sql_order = " order by a.bn_datetime desc ";

 

    // 게시물 수를 세기 위한 쿼리

    $sql = " select count(*) as cnt {$sql_common} ";

    $row = sql_fetch($sql);

    $total_count = $row['cnt'];

 

    if($total_count > 0){

        // 게시물 데이터를 가져오기 위한 쿼리

        $sql = " select a.*, b.bo_subject {$sql_common} {$sql_order} limit {$offset}, {$rows} ";

        $result = sql_query($sql);

 

        $sql2 = "";

        for ($i=0; $row = sql_fetch_array($result); $i++){

            $tmp_write_table = $g5['write_prefix'].$row['bo_table'];

            $bo_table = $row['bo_table'];

 

            if($i > 0)

                $sql2 .= " union ";

            $sql2 .= "(select '{$bo_table}' as bo_table, wr_id, wr_subject, wr_hit, wr_good, wr_nogood

                      from {$tmp_write_table} where wr_is_comment = 0

                      and wr_datetime between '{$term_time}' and '".G5_TIME_YMDHIS."') ";

        }

        // 조건에 따른 정렬

        if ($options === 'wr_hit desc') {

            $sql2 .= " order by wr_hit desc limit {$offset}, {$rows}";

        } else {

            $sql2 .= " order by GREATEST(wr_good, wr_nogood) desc limit {$offset}, {$rows}";

        }

        $result2 = sql_query($sql2);

 

        for ($i=0; $row2 = sql_fetch_array($result2); $i++){

            $list[$i]['href'] = G5_BBS_URL.'/board.php?bo_table='.$row2['bo_table'].'&wr_id='.$row2['wr_id'];

            $list[$i]['subject'] = $row2['wr_subject'];

        }

    }

 

    ob_start();

    ?>

 

    <style type="text/css">

    .lt_full {position:relative;float:left;padding-bottom:10px;width:100%;height:135px;border-bottom:1px solid #e9e9e9}

    .lt2 {position:relative;float:left;padding-bottom:10px;width:354px;}

    .lt2 ul {margin:0 0 0 0;padding:0;list-style:none}

    .lt2 li {padding:0}

 

    /* 반응형 스타일 추가 */

    @media (max-width: 768px) {

        .lt2 {width: 48%;} /* 태블릿에서 두 개 열 */

    }

 

    @media (max-width: 480px) {

        .lt2 {width: 100%;} /* 모바일에서 한 개 열 */

    }

    </style>

 

    <div class="lt_full">

    <div class="lt2">

        <ul>

        <?php for ($i=0; $i<count($list); $i++) {  ?>

            <li>

                <?php

                echo "<a href=\"".$list[$i]['href']."\">";

                    echo "<img src='".G5_URL."/img/num_".($i+1).".gif'> ";

                    echo "<strong>".$list[$i]['subject']."</strong>";

 

                if ($list[$i]['comment_cnt'])

                    echo $list[$i]['comment_cnt'];

 

                echo "</a>";

                ?>

            </li>

        <?php

            if (($i+1)%($rows/2)==0) echo "</ul></div><div class='lt2'><ul>";

            }

        ?>

        <?php if (count($list) == 0) { // 게시물이 없을 때 ?>

        <li>게시물이 없습니다.</li>

        <?php } ?>

        </ul>

    </div>

    </div>

 

    <?php

    $content = ob_get_contents();

    ob_end_clean();

 

    // 페이지네이션 처리

    $total_pages = ceil($total_count / $rows);

    $pagination = '<div class="pagination">';

    for ($i = 1; $i <= $total_pages; $i++) {

        $active_class = ($i == $page) ? 'active' : '';

        $pagination .= '<a href="#" class="page-link ' . $active_class . '" data-page="' . $i . '">' . $i . '</a> ';

    }

    $pagination .= '</div>';

 

    return $content . $pagination;

}

?>

 

<!DOCTYPE html>

<html lang="ko">

<head>

<meta charset="UTF-8">

<title>인기글</title>

<style>

.tab_list {

    margin-bottom: 10px; /* 탭 콘텐츠와 겹치지 않도록 여백 추가 */

    background-color: white; /* 탭 배경색을 흰색으로 설정 */

}

.tab_list ul {

    position: relative;

    margin: 0;

    padding: 0;

    border-bottom: 1px solid #ccc;

    font-family: Tahoma, Sans-serif;

    font-size: 12px;

    list-style: none;

    display: flex;

    flex-wrap: nowrap; /* 탭이 한 줄로 나오도록 설정 */

    background-color: white; /* 탭 배경색을 흰색으로 설정 */

}

.tab_list ul:after {

    display: block;

    clear: both;

    content: "";

}

.tab_list li {

    float: left;

    margin: 0; /* 탭 사이의 마진 제거 */

}

.tab_list li a {

    float: left;

    position: relative;

    border: 1px solid #ccc;

    border-bottom: none; /* 비활성화된 탭의 하단 경계선 제거 */

    background: transparent;

    color: #333; /* 비활성화된 탭의 텍스트 색상 */

    text-decoration: none;

    white-space: nowrap; /* 텍스트가 한 줄로 나오도록 설정 */

    overflow: hidden;

    text-overflow: ellipsis; /* 텍스트가 길 경우 생략 기호(...) 추가 */

    font-weight: normal; /* 비활성화된 탭의 텍스트는 보통 */

}

.tab_list li.active a {

    color: #000; /* 활성화된 탭의 텍스트 색상 */

    font-weight: bold; /* 활성화된 탭의 텍스트는 bold */

    border-bottom: 1px solid #fff; /* 활성화된 탭의 하단 경계선 설정 */

}

.tab_list li a span {

    display: inline-block;

    padding: 6px 25px;

    letter-spacing: -1px;

    cursor: pointer;

}

.tab_list li ul {

    display: none;

    position: absolute;

    top: 40px;

    left: 0;

    width: 100%;

    margin: 0;

    padding: 0;

    border: 0;

    list-style: none;

}

.tab_list li li {

    float: none;

    position: relative;

    margin: 0 0 8px 8px;

    color: #999;

}

.tab_list li li a {

    float: none;

    margin: 0;

    padding: 0;

    border: 0 !important;

    background: transparent;

    font-weight: normal;

    color: #333 !important;

    letter-spacing: normal;

}

.tab_list li ul {

    margin-top: -20px;

    display: block;

}

 

/* 반응형 스타일 추가 */

@media (max-width: 768px) {

    .tab_list ul {

        display: block;

    }

    .tab_list li {

        width: 48%;

        margin: 0; /* 태블릿에서 두 개 열 */

    }

}

 

@media (max-width: 480px) {

    .tab_list ul {

        display: flex;

        flex-wrap: nowrap; /* 모바일에서도 가로 정렬 유지 */

        overflow-x: auto; /* 탭이 한 줄로 나열되도록 스크롤 가능 */

    }

    .tab_list li {

        width: auto;

        margin: 0;

    }

    .tab_list li ul {

        top: auto;

        left: auto;

        position: relative;

    }

    .tab-content {

        display: flex;

        flex-wrap: wrap;

        background-color: white; /* 탭 콘텐츠 배경색을 흰색으로 설정 */

    }

    .tab-content .lt2 {

        width: 50%; /* 왼쪽과 오른쪽에 절반씩 할당 */

        box-sizing: border-box;

        padding: 0 5px; /* 좌우 여백 추가 */

    }

    .tab-content .lt2 ul {

        display: flex;

        flex-direction: column;

    }

    .tab-content .lt2 ul li {

        margin-bottom: 10px; /* 게시물 사이 여백 추가 */

    }

}

.tab-content {

    display: none; /* 기본적으로 콘텐츠를 숨깁니다 */

    padding: 20px;

    border: 1px solid #ccc;

    background: white; /* 탭 콘텐츠 배경색을 흰색으로 설정 */

}

.tab-content.active {

    display: block; /* 활성화된 탭의 콘텐츠만 보입니다 */

    border: none; /* 테두리 제거 */

    padding: 0; /* 여백 제거 */

    background: white; /* 배경색 제거 */

}

.pagination {

    text-align: center;

    margin-top: 10px;

    background-color: white; /* 페이지네이션 배경색을 흰색으로 설정 */

}

.pagination .page-link {

    display: inline-block;

    padding: 5px 10px;

    margin: 0 2px;

    border: 1px solid #ccc;

    color: #333;

    text-decoration: none;

}

.pagination .page-link:hover {

    background: #eee;

}

.pagination .page-link.active {

    background: #333;

    color: #fff;

}

</style>

</head>

<body>

<div class="tab_list m1">

<ul>

<li class="m1 active">

<a href="#tab1"><span>일간 조회수</span></a>

</li>

<li class="m2">

<a href="#tab2"><span>일간 추천수</span></a>

</li>

<li class="m3">

<a href="#tab3"><span>주간 조회수</span></a>

</li>

<li class="m4">

<a href="#tab4"><span>주간 추천수</span></a>

</li>

</ul>

</div>

 

<div id="tab1" class="tab-content active">

  <?php echo latest_popular(10, 40, '일간', 'wr_hit desc', 1); ?>

</div>

<div id="tab2" class="tab-content">

  <?php echo latest_popular(10, 40, '일간', 'GREATEST(wr_good, wr_nogood) desc', 1); ?>

</div>

<div id="tab3" class="tab-content">

  <?php echo latest_popular(10, 40, '주간', 'wr_hit desc', 1); ?>

</div>

<div id="tab4" class="tab-content">

  <?php echo latest_popular(10, 40, '주간', 'GREATEST(wr_good, wr_nogood) desc', 1); ?>

</div>

 

<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>

<script type="text/javascript">

jQuery(function($){

    var tab = $('.tab_list');

    tab.removeClass('js_off');

    function onSelectTab(){

        var t = $(this);

        var target = $(t.attr('href'));

 

        $('.tab-content').removeClass('active'); // 모든 탭 콘텐츠를 숨깁니다

        target.addClass('active'); // 선택된 탭 콘텐츠만 보이게 합니다

 

        $('.tab_list ul li').removeClass('active'); // 모든 탭을 비활성화합니다

        t.parent().addClass('active'); // 선택된 탭을 활성화합니다

 

        return false;

    }

    tab.find('>ul>li>a').click(onSelectTab).focus(onSelectTab);

    $('.tab_list ul li:first-child a').click(); // 첫 번째 탭을 기본으로 활성화합니다

 

    $(document).on('click', '.page-link', function(e) {

        e.preventDefault();

        var page = $(this).data('page');

        var tabContent = $(this).closest('.tab-content');

        var term = tabContent.attr('id') === 'tab1' || tabContent.attr('id') === 'tab2' ? '일간' : '주간';

        var options = tabContent.attr('id') === 'tab1' || tabContent.attr('id') === 'tab3' ? 'wr_hit desc' : 'GREATEST(wr_good, wr_nogood) desc';

 

        $.ajax({

            url: window.location.href, // 현재 페이지 URL로 요청

            type: 'GET',

            data: {

                rows: 10,

                subject_len: 40,

                term: term,

                options: options,

                page: page,

                ajax: true // ajax 요청을 구분하기 위해 추가

            },

            success: function(data) {

                var newContent = $(data).find('#' + tabContent.attr('id')).html();

                tabContent.html(newContent);

            }

        });

    });

});

</script>

 

<?php

// Ajax 요청을 처리

if(isset($_GET['ajax']) && $_GET['ajax'] == true) {

    $rows = $_GET['rows'];

    $subject_len = $_GET['subject_len'];

    $term = $_GET['term'];

    $options = $_GET['options'];

    $page = $_GET['page'];

    echo latest_popular($rows, $subject_len, $term, $options, $page);

    exit;

}

?>

</body>

</html>

 

이건 그누보드에 올라온 인기글관련 php파일을 수정한 것입니다..

한 탭에서 10개의 게시물이 넘어가면 10개당 1페이지씩 증가하도록 페이지네이션 기능을 넣었습니다

근데 문제는 페이지는 잘 증가하는데 해당 페이지를 클릭해도 1페이지의 게시물만 보입니다

(15개의 게시물이 있다면 2페이지를 누르면 11~15까지의 게시물이 나와야하는데 여전히 1~10까지의 게시물이 나타납니다)

 

그렇다고 2페이지의 페이지네이션자체가 문젠지 알아보려고 

<div id="tab1" class="tab-content active">

  <?php echo latest_popular(10, 40, '일간', 'wr_hit desc', 1); ?>

</div>

<div id="tab2" class="tab-content">

  <?php echo latest_popular(10, 40, '일간', 'GREATEST(wr_good, wr_nogood) desc', 1); ?>

</div>

<div id="tab3" class="tab-content">

  <?php echo latest_popular(10, 40, '주간', 'wr_hit desc', 1); ?>

</div>

<div id="tab4" class="tab-content">

  <?php echo latest_popular(10, 40, '주간', 'GREATEST(wr_good, wr_nogood) desc', 1); ?>

</div>

 

이 코드에서 1을 2로 바꿔보았습니다(페이지 번호입니다)

만약 15개의 게시물이 있다면 이경우엔 1페이지를 누르든 2페이지를 누르든 2페이지에 해당하는 게시물(11~15번)만 나타납니다

ajax에서 해당 페이지를 클릭할때 해당 페이지에 해당하는 게시물들을 가져오는 부분에 오류가 있는 거같은데 도움 주실 분 있으신가요ㅜㅜ 

이 질문에 댓글 쓰기 :

답변 2

아래의 코드를 한번 참고해 보시겠어요...

 

 

 

<?php

if (!defined('_GNUBOARD_')) exit;

// 인기글 추출
function latest_popular($rows=10, $subject_len=40, $term='', $options='', $page=1)
{
    global $g5;

    switch($term){
        case '일간':
            $term_time = date("Y-m-d H:i:s", G5_SERVER_TIME-3600*24);
            break;
        case '주간':
            $term_time = date("Y-m-d H:i:s", G5_SERVER_TIME-3600*24*7);
            break;
        default:
            $term_time = date("Y-m-d H:i:s", G5_SERVER_TIME-3600*24);
            break;
    }

    $list = array();
    $offset = ($page - 1) * $rows;

    // 전체 게시판에서 인기글 추출
    $sql_between = " a.bn_datetime between '$term_time' and '".G5_TIME_YMDHIS."' ";
    $sql_common = " from {$g5['board_new_table']} a, {$g5['board_table']} b
                    where a.bo_table = b.bo_table and b.bo_use_search = 1
                    and a.wr_id = a.wr_parent and {$sql_between} ";
    $sql_order = " order by a.bn_datetime desc ";

    // 게시물 수를 세기 위한 쿼리
    $sql = " select count(*) as cnt {$sql_common} ";
    $row = sql_fetch($sql);
    $total_count = $row['cnt'];

    if($total_count > 0){
        // 게시물 데이터를 가져오기 위한 쿼리
        $sql = " select a.*, b.bo_subject {$sql_common} {$sql_order} limit {$offset}, {$rows} ";
        $result = sql_query($sql);

        $sql2 = "";
        for ($i=0; $row = sql_fetch_array($result); $i++){
            $tmp_write_table = $g5['write_prefix'].$row['bo_table'];
            $bo_table = $row['bo_table'];

            if($i > 0)
                $sql2 .= " union ";
            $sql2 .= "(select '{$bo_table}' as bo_table, wr_id, wr_subject, wr_hit, wr_good, wr_nogood
                      from {$tmp_write_table} where wr_is_comment = 0
                      and wr_datetime between '{$term_time}' and '".G5_TIME_YMDHIS."') ";
        }
        // 조건에 따른 정렬
        if ($options === 'wr_hit desc') {
            $sql2 .= " order by wr_hit desc limit {$offset}, {$rows}";
        } else {
            $sql2 .= " order by GREATEST(wr_good, wr_nogood) desc limit {$offset}, {$rows}";
        }
        $result2 = sql_query($sql2);

        for ($i=0; $row2 = sql_fetch_array($result2); $i++){
            $list[$i]['href'] = G5_BBS_URL.'/board.php?bo_table='.$row2['bo_table'].'&wr_id='.$row2['wr_id'];
            $list[$i]['subject'] = $row2['wr_subject'];
        }
    }

    ob_start();
    ?>
    <style type="text/css">
    .lt_full {position:relative;float:left;padding-bottom:10px;width:100%;height:135px;border-bottom:1px solid #e9e9e9}
    .lt2 {position:relative;float:left;padding-bottom:10px;width:354px;}
    .lt2 ul {margin:0 0 0 0;padding:0;list-style:none}
    .lt2 li {padding:0}

    /* 반응형 스타일 추가 */
    @media (max-width: 768px) {
        .lt2 {width: 48%;} /* 태블릿에서 두 개 열 */
    }

    @media (max-width: 480px) {
        .lt2 {width: 100%;} /* 모바일에서 한 개 열 */
    }
    </style>

    <div class="lt_full">
    <div class="lt2">
        <ul>
        <?php for ($i=0; $i<count($list); $i++) {  ?>
            <li>
                <?php
                echo "<a href=\"".$list[$i]['href']."\">";
                    echo "<img src='".G5_URL."/img/num_".($i+1).".gif'> ";
                    echo "<strong>".$list[$i]['subject']."</strong>";

                if ($list[$i]['comment_cnt'])
                    echo $list[$i]['comment_cnt'];

                echo "</a>";
                ?>
            </li>
        <?php
            if (($i+1)%($rows/2)==0) echo "</ul></div><div class='lt2'><ul>";
            }
        ?>
        <?php if (count($list) == 0) { // 게시물이 없을 때 ?>
        <li>게시물이 없습니다.</li>
        <?php } ?>
        </ul>
    </div>
    </div>

    <?php
    $content = ob_get_contents();
    ob_end_clean();

    // 페이지네이션 처리
    $total_pages = ceil($total_count / $rows);
    $pagination = '<div class="pagination">';
    for ($i = 1; $i <= $total_pages; $i++) {
        $active_class = ($i == $page) ? 'active' : '';
        $pagination .= '<a href="#" class="page-link ' . $active_class . '" data-page="' . $i . '">' . $i . '</a> ';
    }
    $pagination .= '</div>';

    return $content . $pagination;
}

?>

<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8">
<title>인기글</title>
<style>
.tab_list {
    margin-bottom: 10px; /* 탭 콘텐츠와 겹치지 않도록 여백 추가 */
    background-color: white; /* 탭 배경색을 흰색으로 설정 */
}
.tab_list ul {
    position: relative;
    margin: 0;
    padding: 0;
    border-bottom: 1px solid #ccc;
    font-family: Tahoma, Sans-serif;
    font-size: 12px;
    list-style: none;
    display: flex;
    flex-wrap: nowrap; /* 탭이 한 줄로 나오도록 설정 */
    background-color: white; /* 탭 배경색을 흰색으로 설정 */
}
.tab_list ul:after {
    display: block;
    clear: both;
    content: "";
}
.tab_list li {
    float: left;
    margin: 0; /* 탭 사이의 마진 제거 */
}
.tab_list li a {
    float: left;
    position: relative;
    border: 1px solid #ccc;
    border-bottom: none; /* 비활성화된 탭의 하단 경계선 제거 */
    background: transparent;
    color: #333; /* 비활성화된 탭의 텍스트 색상 */
    text-decoration: none;
    white-space: nowrap; /* 텍스트가 한 줄로 나오도록 설정 */
    overflow: hidden;
    text-overflow: ellipsis; /* 텍스트가 길 경우 생략 기호(...) 추가 */
    font-weight: normal; /* 비활성화된 탭의 텍스트는 보통 */
}
.tab_list li.active a {
    color: #000; /* 활성화된 탭의 텍스트 색상 */
    font-weight: bold; /* 활성화된 탭의 텍스트는 bold */
    border-bottom: 1px solid #fff; /* 활성화된 탭의 하단 경계선 설정 */
}
.tab_list li a span {
    display: inline-block;
    padding: 6px 25px;
    letter-spacing: -1px;
    cursor: pointer;
}
.tab_list li ul {
    display: none;
    position: absolute;
    top: 40px;
    left: 0;
    width: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    list-style: none;
}
.tab_list li li {
    float: none;
    position: relative;
    margin: 0 0 8px 8px;
    color: #999;
}
.tab_list li li a {
    float: none;
    margin: 0;
    padding: 0;
    border: 0 !important;
    background: transparent;
    font-weight: normal;
    color: #333 !important;
    letter-spacing: normal;
}
.tab_list li ul {
    margin-top: -20px;
    display: block;
}

/* 반응형 스타일 추가 */
@media (max-width: 768px) {
    .tab_list ul {
        display: block;
    }
    .tab_list li {
        width: 48%;
        margin: 0; /* 태블릿에서 두 개 열 */
    }
}

@media (max-width: 480px) {
    .tab_list ul {
        display: flex;
        flex-wrap: nowrap; /* 모바일에서도 가로 정렬 유지 */
        overflow-x: auto; /* 탭이 한 줄로 나열되도록 스크롤 가능 */
    }
    .tab_list li {
        width: auto;
        margin: 0;
    }
    .tab_list li ul {
        top: auto;
        left: auto;
        position: relative;
    }
    .tab-content {
        display: flex;
        flex-wrap: wrap;
        background-color: white; /* 탭 콘텐츠 배경색을 흰색으로 설정 */
    }
    .tab-content .lt2 {
        width: 50%; /* 왼쪽과 오른쪽에 절반씩 할당 */
        box-sizing: border-box;
        padding: 0 5px; /* 좌우 여백 추가 */
    }
    .tab-content .lt2 ul {
        display: flex;
        flex-direction: column;
    }
    .tab-content .lt2 ul li {
        margin-bottom: 10px; /* 게시물 사이 여백 추가 */
    }
}
.tab-content {
    display: none; /* 기본적으로 콘텐츠를 숨깁니다 */
    padding: 20px;
    border: 1px solid #ccc;
    background: white; /* 탭 콘텐츠 배경색을 흰색으로 설정 */
}
.tab-content.active {
    display: block; /* 활성화된 탭의 콘텐츠만 보입니다 */
    border: none; /* 테두리 제거 */
    padding: 0; /* 여백 제거 */
    background: white; /* 배경색 제거 */
}
.pagination {
    text-align: center;
    margin-top: 10px;
    background-color: white; /* 페이지네이션 배경색을 흰색으로 설정 */
}
.pagination .page-link {
    display: inline-block;
    padding: 5px 10px;
    margin: 0 2px;
    border: 1px solid #ccc;
    color: #333;
    text-decoration: none;
}
.pagination .page-link:hover {
    background: #eee;
}
.pagination .page-link.active {
    background: #333;
    color: #fff;
}
</style>
</head>
<body>
<div class="tab_list m1">
<ul>
<li class="m1 active">
<a href="#tab1"><span>일간 조회수</span></a>
</li>
<li class="m2">
<a href="#tab2"><span>일간 추천수</span></a>
</li>
<li class="m3">
<a href="#tab3"><span>주간 조회수</span></a>
</li>
<li class="m4">
<a href="#tab4"><span>주간 추천수</span></a>
</li>
</ul>
</div>

<div id="tab1" class="tab-content active">
  <?php echo latest_popular(10, 40, '일간', 'wr_hit desc', 1); ?>
</div>
<div id="tab2" class="tab-content">
  <?php echo latest_popular(10, 40, '일간', 'GREATEST(wr_good, wr_nogood) desc', 1); ?>
</div>
<div id="tab3" class="tab-content">
  <?php echo latest_popular(10, 40, '주간', 'wr_hit desc', 1); ?>
</div>
<div id="tab4" class="tab-content">
  <?php echo latest_popular(10, 40, '주간', 'GREATEST(wr_good, wr_nogood) desc', 1); ?>
</div>

<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script type="text/javascript">
jQuery(function($){
    var tab = $('.tab_list');
    tab.removeClass('js_off');
    function onSelectTab(){
        var t = $(this);
        var target = $(t.attr('href'));

        $('.tab-content').removeClass('active'); // 모든 탭 콘텐츠를 숨깁니다
        target.addClass('active'); // 선택된 탭 콘텐츠만 보이게 합니다

        $('.tab_list ul li').removeClass('active'); // 모든 탭을 비활성화합니다
        t.parent().addClass('active'); // 선택된 탭을 활성화합니다

        return false;
    }
    tab.find('>ul>li>a').click(onSelectTab).focus(onSelectTab);
    $('.tab_list ul li:first-child a').click(); // 첫 번째 탭을 기본으로 활성화합니다

    $(document).on('click', '.page-link', function(e) {
        e.preventDefault();
        var page = $(this).data('page');
        var tabContent = $(this).closest('.tab-content');
        var term = tabContent.attr('id') === 'tab1' || tabContent.attr('id') === 'tab2' ? '일간' : '주간';
        var options = tabContent.attr('id') === 'tab1' || tabContent.attr('id') === 'tab3' ? 'wr_hit desc' : 'GREATEST(wr_good, wr_nogood) desc';

        $.ajax({
            url: window.location.href, // 현재 페이지 URL로 요청
            type: 'GET',
            data: {
                rows: 10,
                subject_len: 40,
                term: term,
                options: options,
                page: page,
                ajax: true // ajax 요청을 구분하기 위해 추가
            },
            success: function(data) {
                var newContent = $(data).find('#' + tabContent.attr('id')).html();
                tabContent.html(newContent);
            }
        });
    });
});
</script>

<?php
// Ajax 요청을 처리
if(isset($_GET['ajax']) && $_GET['ajax'] == true) {
    $rows = $_GET['rows'];
    $subject_len = $_GET['subject_len'];
    $term = $_GET['term'];
    $options = $_GET['options'];
    $page = $_GET['page'];
    echo latest_popular($rows, $subject_len, $term, $options, $page);
    exit;
}
?>
</body>
</html>

 

 

 

 

방법1.

원글수와 카운팅이 맞지 않아서 그럴수도 있습니다.

관리자페이지에서 해당 게시판의 설정에 들어가셔서

 

1982090578_1722784068.7718.png

 

이렇게 카운트 조정을 한번 해보시기 바랍니다.

 

방법2.

최근글 형식의 글을 가져오려면 board_new 와 관련있는데

1982090578_1722784200.3669.png

이렇게 설정일이 지난 최신게시물은 자동삭제되게 됩니다.

해당 날짜를 더 늘려서 채크해보세요.

 

앗 저 php는 게시판이 따로 있는것이 아니라 저 파일 자체가 index페이지나 board에 삽입되어서 나타나는 형식입니다ㅜ 그래서 관리자페이지에서 게시판설정으로 들어갈 수 없습니다ㅠㅠ

게시판 리스트를 말하는게 아니라 최근글(latest) 형식을 말하는거에요..

위 코드를 보면

$sql_common = " from {$g5['board_new_table']} a, {$g5['board_table']} b

                    where a.bo_table = b.bo_table and b.bo_use_search = 1

                    and a.wr_id = a.wr_parent and {$sql_between} ";

    $sql_order = " order by a.bn_datetime desc ";

이렇게 board_new_table 과 board_table 을 참조하고 있습니다.

그래서 게시글 카운트 및 최신글(board_new) 의 소유 기간을 늘려보라는거에요.

답변을 작성하시기 전에 로그인 해주세요.
전체 3
QA 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT