분류(카테고리) 갯수 표시
위의 이미지 처럼 분류 항목에 갯수를 표시하려는 분들이 많은 것 같아 팁으로 소개해봅니다.
http://sir.co.kr/g5_tip/2604?sfl=wr_subject%7C%7Cwr_content&stx=%EB%B6%84%EB%A5%98+%EC%88%AB%EC%9E%90&page=1
위의 링크에도 "둘째삼식"님이 게시한 내용이 있지만 좀더 간단하게 함수로 만들어 보았습니다.
적용하려는 게시판 스킨의 list.skin.php 상단에 아래와 같이 추가 및 수정합니다.
[code]
<?php
if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가
//카테고리(분류) 갯수 구하기
function category_count($ca_name='')
{
global $g5, $bo_table;
if ($ca_name) $sql_where = " where ca_name = '".$ca_name."' ";
else $sql_where = " where ca_name != '' ";
$row = sql_fetch(" select count(*) as cnt from ".$g5['write_prefix'].$bo_table.$sql_where);
return $row['cnt'];
}
//갯수반영 카테고리 옵션
function new_category_option($bo_table)
{
global $board;
$category_option = '';
if ($board['bo_use_category']) {
$category_href = G5_BBS_URL.'/board.php?bo_table='.$bo_table;
$category_option .= '<li><a href="'.$category_href.'"';
if ($sca=='') $category_option .= ' id="bo_cate_on"';
$category_option .= '>전체('.category_count().')</a></li>';
$categories = explode('|', $board['bo_category_list']); // 구분자가 , 로 되어 있음
for ($i=0; $i<count($categories); $i++) {
$category = trim($categories[$i]);
if ($category=='') continue;
$category_option .= '<li><a href="'.($category_href."&sca=".urlencode($category)).'"';
$category_msg = '';
if ($category==$sca) { // 현재 선택된 카테고리라면
$category_option .= ' id="bo_cate_on"';
$category_msg = '<span class="sound_only">열린 분류 </span>';
}
$category_option .= '>'.$category_msg.$category.'('.category_count($category).')</a></li>';
}
}
return $category_option;
}
// 여기까지 추가함
~ 중략 ~
<?php echo $category_option ?> <!-- 이부분을 찾아서 아래와 같이 수정함-->
<?php echo new_category_option($bo_table);?>
[/code]
http://sir.co.kr/g5_tip/2604?sfl=wr_subject%7C%7Cwr_content&stx=%EB%B6%84%EB%A5%98+%EC%88%AB%EC%9E%90&page=1
위의 링크에도 "둘째삼식"님이 게시한 내용이 있지만 좀더 간단하게 함수로 만들어 보았습니다.
적용하려는 게시판 스킨의 list.skin.php 상단에 아래와 같이 추가 및 수정합니다.
[code]
<?php
if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가
//카테고리(분류) 갯수 구하기
function category_count($ca_name='')
{
global $g5, $bo_table;
if ($ca_name) $sql_where = " where ca_name = '".$ca_name."' ";
else $sql_where = " where ca_name != '' ";
$row = sql_fetch(" select count(*) as cnt from ".$g5['write_prefix'].$bo_table.$sql_where);
return $row['cnt'];
}
//갯수반영 카테고리 옵션
function new_category_option($bo_table)
{
global $board;
$category_option = '';
if ($board['bo_use_category']) {
$category_href = G5_BBS_URL.'/board.php?bo_table='.$bo_table;
$category_option .= '<li><a href="'.$category_href.'"';
if ($sca=='') $category_option .= ' id="bo_cate_on"';
$category_option .= '>전체('.category_count().')</a></li>';
$categories = explode('|', $board['bo_category_list']); // 구분자가 , 로 되어 있음
for ($i=0; $i<count($categories); $i++) {
$category = trim($categories[$i]);
if ($category=='') continue;
$category_option .= '<li><a href="'.($category_href."&sca=".urlencode($category)).'"';
$category_msg = '';
if ($category==$sca) { // 현재 선택된 카테고리라면
$category_option .= ' id="bo_cate_on"';
$category_msg = '<span class="sound_only">열린 분류 </span>';
}
$category_option .= '>'.$category_msg.$category.'('.category_count($category).')</a></li>';
}
}
return $category_option;
}
// 여기까지 추가함
~ 중략 ~
<?php echo $category_option ?> <!-- 이부분을 찾아서 아래와 같이 수정함-->
<?php echo new_category_option($bo_table);?>
[/code]
댓글 7개
10년 전
이 코드 그대로 복사해서 적용해봤는데 전체 카테고리에만 on이 먹힌 상태로 유지되고 나머지 카테고리들은 on이 안 먹히네요- 코드를 몰라 고치지도 못 하겠고.... ^^;
10년 전
위의 소스는 원본 스킨인 basic 스킨을 토대로 작성된 것입니다.
스킨의 list.skin.php 파일 내용 중에 id="bo_cate" 부분이 변경되었거나
style.css의
#bo_cate #bo_cate_on {z-index:2;border:1px solid #565e60;background:#fff;color:#565e60;font-weight:bold} 이 부분이 변경되었다면 bo_cate_on 이 작동되지 않을 수 있습니다.
그리고, bo_cate_on 이 작동되는 상황은 아래와 같습니다.
[code]
if ($category==$sca) { // 현재 선택된 카테고리라면
$category_option .= ' id="bo_cate_on"';
$category_msg = '<span class="sound_only">열린 분류 </span>';
}
[/code]
이 코드의 내용은 주소줄에 $sca 변수값이 존재할 때 #bo_cate_on 의 css가 활성화된다는 의미입니다.
스킨의 list.skin.php 파일 내용 중에 id="bo_cate" 부분이 변경되었거나
style.css의
#bo_cate #bo_cate_on {z-index:2;border:1px solid #565e60;background:#fff;color:#565e60;font-weight:bold} 이 부분이 변경되었다면 bo_cate_on 이 작동되지 않을 수 있습니다.
그리고, bo_cate_on 이 작동되는 상황은 아래와 같습니다.
[code]
if ($category==$sca) { // 현재 선택된 카테고리라면
$category_option .= ' id="bo_cate_on"';
$category_msg = '<span class="sound_only">열린 분류 </span>';
}
[/code]
이 코드의 내용은 주소줄에 $sca 변수값이 존재할 때 #bo_cate_on 의 css가 활성화된다는 의미입니다.
10년 전
네, 그건 저도 봐서 알았지만 스타일 시트의 문제는 아니었어요.
그 문제였다면 애초에 전체 카테고리일 때도 on이 먹히지 않았겠죠....
저는 상단에 global $sca; 이걸 추가해서 문제를 해결했습니다.
(제가 했다기보다 다른 분께 도움을 얻었어요.... ㅎ)
그 문제였다면 애초에 전체 카테고리일 때도 on이 먹히지 않았겠죠....
저는 상단에 global $sca; 이걸 추가해서 문제를 해결했습니다.
(제가 했다기보다 다른 분께 도움을 얻었어요.... ㅎ)
10년 전
앗, 제가 제시해 드린 함수 안에 전역변수 선언이 $board 뿐이었군요...
혹시, 이 팁을 사용하시는 다른 분들은 "이미님"의 댓글을 참고하시어
함수 안에 $sca 를 전역변수로 선언하여 사용하시기 바랍니다.
수정된 부분은 아래와 같습니다.
[code]
//갯수반영 카테고리 옵션
function new_category_option($bo_table)
{
global $board, $sca; //$sca 전역변수로 추가
~ 이하 생략 ~
[/code]
혹시, 이 팁을 사용하시는 다른 분들은 "이미님"의 댓글을 참고하시어
함수 안에 $sca 를 전역변수로 선언하여 사용하시기 바랍니다.
수정된 부분은 아래와 같습니다.
[code]
//갯수반영 카테고리 옵션
function new_category_option($bo_table)
{
global $board, $sca; //$sca 전역변수로 추가
~ 이하 생략 ~
[/code]
8년 전
이거 적용하면 어마어마하게 느려지는데.. 혹시 인덱스 튜닝을 어떻게 해야할지 알려주시면 정말 감사하겠습니다
그누보드 버전은 5.2.7 쓰고 있습니다
그누보드 버전은 5.2.7 쓰고 있습니다
민쯩먼저깔게요
8년 전
감사합니다
민쯩먼저깔게요
8년 전
하지만 어마어마하게라니 겁납니다..ㅎ
이거 1주일에 대해서만 한다면 빠르지 않을까요?
이거 1주일에 대해서만 한다면 빠르지 않을까요?
게시판 목록
그누보드5 팁자료실
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 공지 | 3년 전 | 4402 | ||
| 2694 | 2개월 전 | 188 | ||
| 2693 | 2개월 전 | 148 | ||
| 2692 | 2개월 전 | 158 | ||
| 2691 | 2개월 전 | 174 | ||
| 2690 | 2개월 전 | 326 | ||
| 2689 | 2개월 전 | 233 | ||
| 2688 |
|
2개월 전 | 440 | |
| 2687 | 2개월 전 | 292 | ||
| 2686 |
선택과집중
|
2개월 전 | 329 | |
| 2685 | 2개월 전 | 290 | ||
| 2684 | 2개월 전 | 346 | ||
| 2683 | 2개월 전 | 481 | ||
| 2682 | 2개월 전 | 276 | ||
| 2681 | 2개월 전 | 302 | ||
| 2680 |
선택과집중
|
2개월 전 | 278 | |
| 2679 | 2개월 전 | 330 | ||
| 2678 |
|
3개월 전 | 429 | |
| 2677 |
|
3개월 전 | 502 | |
| 2676 | 3개월 전 | 326 | ||
| 2675 | 3개월 전 | 304 | ||
| 2674 |
선택과집중
|
3개월 전 | 480 | |
| 2673 |
|
3개월 전 | 322 | |
| 2672 | 3개월 전 | 335 | ||
| 2671 | 3개월 전 | 284 | ||
| 2670 | 3개월 전 | 259 | ||
| 2669 | 3개월 전 | 374 | ||
| 2668 | 3개월 전 | 289 | ||
| 2667 |
선택과집중
|
3개월 전 | 483 | |
| 2666 |
선택과집중
|
3개월 전 | 470 | |
| 2665 |
선택과집중
|
3개월 전 | 404 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기