[이윰] View 페이지에서 이전글, 다음글 버튼에 제목과 썸네일을 가져오기
페이지 정보
shadow2fox
2,218 2 2
2021.01.10 13:18:34
짧은주소
-
https://yadolee.com/tip/809 주소복사
본문
View 페이지에서 이전글, 다음글 버튼에 제목과 썸네일을 가져오기
전체목록보이기 사용 체크 유무에 상관없이 View 페이지에서 이전글, 다음글의 버튼이 보이고 각 버튼에 마우스를 올렸을 때 첨부된 이미지, 에디터 이미지, 동영상 썸네일, 외부 이미지 썸네일이 나오도록 해 보자.
외부 이미지의 썸네일도 보여지도록 아래 링크의 선행작업이 필요하다.
https://yadolee.com/bbs/board.php?bo_table=tip&wr_id=817
1. 그누보드/bbs/view.php를 열어 if (!$board['bo_use_list_view']) {를 검색하여 아래와 같이 수정한다.
수정 전{code:php}
if (!$board['bo_use_list_view']) {
if ($sql_search)
$sql_search = " and " . $sql_search;
// 윗글을 얻음
$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply < '{$write['wr_reply']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
$prev = sql_fetch($sql);
// 위의 쿼리문으로 값을 얻지 못했다면
if (! (isset($prev['wr_id']) && $prev['wr_id'])) {
$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num < '{$write['wr_num']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
$prev = sql_fetch($sql);
}
// 아래글을 얻음
$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply > '{$write['wr_reply']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
$next = sql_fetch($sql);
// 위의 쿼리문으로 값을 얻지 못했다면
if (! (isset($next['wr_id']) && $next['wr_id'])) {
$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num > '{$write['wr_num']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
$next = sql_fetch($sql);
}
}
{/code}수정 후{code:php}
// 주석처리, 전체목록보이기 체크시에도 이전글 다음글 버튼 나타내기
//if (!$board['bo_use_list_view']) {
if ($sql_search)
$sql_search = " and " . $sql_search;
// 윗글을 얻음
//$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply < '{$write['wr_reply']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
//추가, 여분필드도 가져오기
$sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply < '{$write['wr_reply']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
$prev = sql_fetch($sql);
// 위의 쿼리문으로 값을 얻지 못했다면
if (! (isset($prev['wr_id']) && $prev['wr_id'])) {
//$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num < '{$write['wr_num']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
//추가, 여분필드도 가져오기
$sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num < '{$write['wr_num']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
$prev = sql_fetch($sql);
}
// 아래글을 얻음
//$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply > '{$write['wr_reply']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
//추가, 여분필드도 가져오기
$sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply > '{$write['wr_reply']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
$next = sql_fetch($sql);
// 위의 쿼리문으로 값을 얻지 못했다면
if (! (isset($next['wr_id']) && $next['wr_id'])) {
//$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num > '{$write['wr_num']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
//추가, 여분필드도 가져오기
$sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num > '{$write['wr_num']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
$next = sql_fetch($sql);
}
//}
{/code}
2. 그누보드5/eyoom/user_program/board/view.skin.php를 열어 적당한 위치에 아래 소스를 넣는다.
{code:php}
// 이전글 프리뷰
if (isset($prev['wr_id']) && $prev['wr_id']) {
$prev_img = get_list_thumbnail($bo_table, $prev['wr_id'], $board['bo_gallery_width'], $board['bo_gallery_height']);
if($prev_img['src']) {
$prev['img_content'] = "<img class='img-responsive' src='".$prev_img['src']."' alt='".$prev_img['alt']."'>";
$prev['img_src'] = $prev_img['src'];
} else {
// wr_4 unserialize
$prev_wr_4 = unserialize($prev['wr_4']);
if(!$prev_wr_4) $prev_wr_4 = array();
if($prev['wr_4']) {
$prev_img['src'] = $prev_wr_4['thumb_src'];
if($prev_img['src']) {
$prev['img_content'] = "<img class='img-responsive' src='".$prev_img['src']."'>";
$prev['img_src'] = $prev_img['src'];
} else {
$prev_img['src'] = $prev_wr_4['extimg_thumb'];
if($prev_img) {
$prev['img_content'] = "<img class='img-responsive' src='".$prev_img['src']."'>";
$prev['img_src'] = $prev_img['src'];
}
}
}
}
}
// 다음글 프리뷰
if (isset($next['wr_id']) && $next['wr_id']) {
$next_img = get_list_thumbnail($bo_table, $next['wr_id'], $board['bo_gallery_width'], $board['bo_gallery_height']);
if($next_img['src']) {
$next['img_content'] = "<img class='img-responsive' src='".$next_img['src']."' alt='".$next_img['alt']."'>";
$next['img_src'] = $next_img['src'];
} else {
// wr_4 unserialize
$next_wr_4 = unserialize($next['wr_4']);
if(!$next_wr_4) $next_wr_4 = array();
if($next['wr_4']) {
$next_img['src'] = $next_wr_4['thumb_src'];
if($next_img['src']) {
$next['img_content'] = "<img class='img-responsive' src='".$next_img['src']."'>";
$next['img_src'] = $next_img['src'];
} else {
$next_img['src'] = $next_wr_4['extimg_thumb'];
if($next_img) {
$next['img_content'] = "<img class='img-responsive' src='".$next_img['src']."'>";
$next['img_src'] = $next_img['src'];
}
}
}
}
}
{/code}
3. 변경하고자 하는 스킨의 view.skin.html을 열어 이전글과 다음글을 아래와 같이 수정한다.
수정 전{code:php}
<!--{? _prev_href}--><li><a href="{_prev_href}" class="btn-e btn-e-light-grey" type="button">이전글</a></li><!--{/}-->
<!--{? _next_href}--><li><a href="{_next_href}" class="btn-e btn-e-light-grey" type="button">다음글</a></li><!--{/}-->
{/code}수정 후{code:php}
<!--{? _prev_href}--><li><a href="{_prev_href}" class="btn btn-danger" type="button"{? !C.G5_IS_MOBILE} data-trigger="hover" data-placement="top auto" title="<i class='far fa-arrow-alt-circle-up'></i> {_prev_wr_subject}" data-toggle="popover" {? _prev_img}data-content="<div class='prev-img'>{_prev.img_content}</div>"{/}{/}>다음글</a></li><!--{/}-->
<!--{? _next_href}--><li><a href="{_next_href}" class="btn btn-warning" type="button"{? !C.G5_IS_MOBILE} data-trigger="hover" data-placement="top auto" title="<i class='far fa-arrow-alt-circle-down'></i> {_next_wr_subject}" data-toggle="popover" {? _next_img}data-content="<div class='next-img'>{_next.img_content}</div>"{/}{/}>이전글</a></li><!--{/}-->
{/code}참고로 위 다음글과 이전글의 버튼 문구가 뒤바뀐 걸 알 수 있는데 버튼 위치나 순서상의 선택이니 본인 판단에 따르도록 하자.
팝업 스타일 정의하도록 view.skin.html 상단에 아래 css를 넣는다.
{code:css}
.popover{max-width:174px}
{? !_prev_img && !_next_img}.popover-content{display:none}{:}.popover-content{display:contents}{/}
.popover-title{font-size:11px;letter-spacing:-1px;line-height:1em;text-overflow:ellipsis;white-space:nowrap;word-wrap:normal;overflow:hidden;background:#fff;border-bottom:none}
.popover-content .prev-img, .popover-content .next-img{overflow:hidden;max-height:125px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}
{/code}
마우스 오버 시 팝업이 작동하도록 view.skin.html 하단 쪽에 아래 스크립트를 넣는다.
{code:js}
$(document).ready(function(){
$('[data-toggle="popover"]').popover({html:true,container:'.board-view-atc',delay:{show:0,hide:0},animation:false});
$('[data-toggle="popover"]').on('shown.bs.popover', function () {
$('.popover-content .prev-img').addClass('animated flipInX');
$('.popover-content .next-img').addClass('animated flipInX');
})
});
{/code}
외부 이미지의 썸네일도 보여지도록 아래 링크의 선행작업이 필요하다.
https://yadolee.com/bbs/board.php?bo_table=tip&wr_id=817
1. 그누보드/bbs/view.php를 열어 if (!$board['bo_use_list_view']) {를 검색하여 아래와 같이 수정한다.
수정 전{code:php}
if (!$board['bo_use_list_view']) {
if ($sql_search)
$sql_search = " and " . $sql_search;
// 윗글을 얻음
$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply < '{$write['wr_reply']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
$prev = sql_fetch($sql);
// 위의 쿼리문으로 값을 얻지 못했다면
if (! (isset($prev['wr_id']) && $prev['wr_id'])) {
$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num < '{$write['wr_num']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
$prev = sql_fetch($sql);
}
// 아래글을 얻음
$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply > '{$write['wr_reply']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
$next = sql_fetch($sql);
// 위의 쿼리문으로 값을 얻지 못했다면
if (! (isset($next['wr_id']) && $next['wr_id'])) {
$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num > '{$write['wr_num']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
$next = sql_fetch($sql);
}
}
{/code}수정 후{code:php}
// 주석처리, 전체목록보이기 체크시에도 이전글 다음글 버튼 나타내기
//if (!$board['bo_use_list_view']) {
if ($sql_search)
$sql_search = " and " . $sql_search;
// 윗글을 얻음
//$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply < '{$write['wr_reply']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
//추가, 여분필드도 가져오기
$sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply < '{$write['wr_reply']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
$prev = sql_fetch($sql);
// 위의 쿼리문으로 값을 얻지 못했다면
if (! (isset($prev['wr_id']) && $prev['wr_id'])) {
//$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num < '{$write['wr_num']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
//추가, 여분필드도 가져오기
$sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num < '{$write['wr_num']}' {$sql_search} order by wr_num desc, wr_reply desc limit 1 ";
$prev = sql_fetch($sql);
}
// 아래글을 얻음
//$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply > '{$write['wr_reply']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
//추가, 여분필드도 가져오기
$sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num = '{$write['wr_num']}' and wr_reply > '{$write['wr_reply']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
$next = sql_fetch($sql);
// 위의 쿼리문으로 값을 얻지 못했다면
if (! (isset($next['wr_id']) && $next['wr_id'])) {
//$sql = " select wr_id, wr_subject, wr_datetime from {$write_table} where wr_is_comment = 0 and wr_num > '{$write['wr_num']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
//추가, 여분필드도 가져오기
$sql = " select wr_id, wr_subject, wr_datetime, wr_4 from {$write_table} where wr_is_comment = 0 and wr_num > '{$write['wr_num']}' {$sql_search} order by wr_num, wr_reply limit 1 ";
$next = sql_fetch($sql);
}
//}
{/code}
2. 그누보드5/eyoom/user_program/board/view.skin.php를 열어 적당한 위치에 아래 소스를 넣는다.
{code:php}
// 이전글 프리뷰
if (isset($prev['wr_id']) && $prev['wr_id']) {
$prev_img = get_list_thumbnail($bo_table, $prev['wr_id'], $board['bo_gallery_width'], $board['bo_gallery_height']);
if($prev_img['src']) {
$prev['img_content'] = "<img class='img-responsive' src='".$prev_img['src']."' alt='".$prev_img['alt']."'>";
$prev['img_src'] = $prev_img['src'];
} else {
// wr_4 unserialize
$prev_wr_4 = unserialize($prev['wr_4']);
if(!$prev_wr_4) $prev_wr_4 = array();
if($prev['wr_4']) {
$prev_img['src'] = $prev_wr_4['thumb_src'];
if($prev_img['src']) {
$prev['img_content'] = "<img class='img-responsive' src='".$prev_img['src']."'>";
$prev['img_src'] = $prev_img['src'];
} else {
$prev_img['src'] = $prev_wr_4['extimg_thumb'];
if($prev_img) {
$prev['img_content'] = "<img class='img-responsive' src='".$prev_img['src']."'>";
$prev['img_src'] = $prev_img['src'];
}
}
}
}
}
// 다음글 프리뷰
if (isset($next['wr_id']) && $next['wr_id']) {
$next_img = get_list_thumbnail($bo_table, $next['wr_id'], $board['bo_gallery_width'], $board['bo_gallery_height']);
if($next_img['src']) {
$next['img_content'] = "<img class='img-responsive' src='".$next_img['src']."' alt='".$next_img['alt']."'>";
$next['img_src'] = $next_img['src'];
} else {
// wr_4 unserialize
$next_wr_4 = unserialize($next['wr_4']);
if(!$next_wr_4) $next_wr_4 = array();
if($next['wr_4']) {
$next_img['src'] = $next_wr_4['thumb_src'];
if($next_img['src']) {
$next['img_content'] = "<img class='img-responsive' src='".$next_img['src']."'>";
$next['img_src'] = $next_img['src'];
} else {
$next_img['src'] = $next_wr_4['extimg_thumb'];
if($next_img) {
$next['img_content'] = "<img class='img-responsive' src='".$next_img['src']."'>";
$next['img_src'] = $next_img['src'];
}
}
}
}
}
{/code}
3. 변경하고자 하는 스킨의 view.skin.html을 열어 이전글과 다음글을 아래와 같이 수정한다.
수정 전{code:php}
<!--{? _prev_href}--><li><a href="{_prev_href}" class="btn-e btn-e-light-grey" type="button">이전글</a></li><!--{/}-->
<!--{? _next_href}--><li><a href="{_next_href}" class="btn-e btn-e-light-grey" type="button">다음글</a></li><!--{/}-->
{/code}수정 후{code:php}
<!--{? _prev_href}--><li><a href="{_prev_href}" class="btn btn-danger" type="button"{? !C.G5_IS_MOBILE} data-trigger="hover" data-placement="top auto" title="<i class='far fa-arrow-alt-circle-up'></i> {_prev_wr_subject}" data-toggle="popover" {? _prev_img}data-content="<div class='prev-img'>{_prev.img_content}</div>"{/}{/}>다음글</a></li><!--{/}-->
<!--{? _next_href}--><li><a href="{_next_href}" class="btn btn-warning" type="button"{? !C.G5_IS_MOBILE} data-trigger="hover" data-placement="top auto" title="<i class='far fa-arrow-alt-circle-down'></i> {_next_wr_subject}" data-toggle="popover" {? _next_img}data-content="<div class='next-img'>{_next.img_content}</div>"{/}{/}>이전글</a></li><!--{/}-->
{/code}참고로 위 다음글과 이전글의 버튼 문구가 뒤바뀐 걸 알 수 있는데 버튼 위치나 순서상의 선택이니 본인 판단에 따르도록 하자.
팝업 스타일 정의하도록 view.skin.html 상단에 아래 css를 넣는다.
{code:css}
.popover{max-width:174px}
{? !_prev_img && !_next_img}.popover-content{display:none}{:}.popover-content{display:contents}{/}
.popover-title{font-size:11px;letter-spacing:-1px;line-height:1em;text-overflow:ellipsis;white-space:nowrap;word-wrap:normal;overflow:hidden;background:#fff;border-bottom:none}
.popover-content .prev-img, .popover-content .next-img{overflow:hidden;max-height:125px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}
{/code}
마우스 오버 시 팝업이 작동하도록 view.skin.html 하단 쪽에 아래 스크립트를 넣는다.
{code:js}
$(document).ready(function(){
$('[data-toggle="popover"]').popover({html:true,container:'.board-view-atc',delay:{show:0,hide:0},animation:false});
$('[data-toggle="popover"]').on('shown.bs.popover', function () {
$('.popover-content .prev-img').addClass('animated flipInX');
$('.popover-content .next-img').addClass('animated flipInX');
})
});
{/code}
추천인 2
레벨 155
경험치 3,584,591
Progress Bar 8.8%
- 가입일 : 2015-03-10 12:21:44
- 서명 : 인간에게 가장 큰 선물은
자기 자신에게 기회를 주는 것이다.
- 크리스 가드너, Chris Gardner -
- 자기소개 : There's never a shortcut to happiness.
-
[자유 게시판] Andai Aku Bisa - Tulus2026-02-16
-
1 [Web Server Tip] 그누보드(영카트) 5.6.24 +12026-02-16
-
[골라먹는 요리] 호불호 없는 중화불고기2026-02-15
-
[좋은 생각] 더 이상 단순화할 수 없을 만큼 모든 것을 단순화시켜야 한다2026-02-15
-
[좋은 생각] 당신이 아는 것은 중요하다2026-02-15
-
[좋은 생각] 침묵을 배우는 데는 평생이 걸린다2026-02-15
-
[좋은 생각] 나무를 심어야 할 가장 좋은 시기2026-02-15
-
[좋은 생각] 마음을 다치고 싶지 않을 때 숨는다2026-02-15
-
[자유 게시판] 무엇보다 건강하시고 어제 보다 나은 오늘, 오늘 보다 나은 내일을 위해 그렇게 행복함이 넘쳐나시길 기원드립니다 새해 복 많이 받으세요2026-02-16
-
[생활 정보] 15원 추가 적립이 있네요 https://campaign2.naver.com/npay/v2/click-point/?eventId=cr_2026012802_2602_01772026-02-10
-
[생활 정보] 15원 줍줍 아직 수확 전이시면 체크해 보세요 https://campaign2.naver.com/npay/v2/click-point/?eventId=cr_2026012802_2602_01272026-02-07
-
[생활 정보] 가격이 착하다 싶더니 할인이 사라지고 일반가 30,900원으로 판매하네요2026-01-28
-
[일일 메모장] 안타까운 소식입니다. 민주 진영의 거목이였던 이해찬 전 대표님 정말 고생 많으셨습니다. 이제 편히 쉬십시오.2026-01-25
-
[자유 게시판] 올 한 해도 잘 부탁드립니다. 새해 복 많이 받으세요.2026-01-06
-
[일일 메모장] 무슨 말이 필요할까요 삼가 조의를 표하며 고인의 명복을 빕니다 영면하세요2026-01-05
-
[생활 정보] 이번 년도도 잘 정리해 주셨네요 감사드립니다2026-01-01


댓글2
하늘구장님의 댓글
내사랑님의 댓글
축하합니다. 첫 댓글로 19경험치를 획득하였습니다.