[이윰] 새로고침 없이 댓글을 달거나 삭제할 수 있는 ajax 댓글 시스템으로 교체하기
페이지 정보
shadow2fox
4,223 4 2
2018.12.11 14:35:15
짧은주소
-
https://yadolee.com/tip/602 주소복사
본문
새로고침 없이 댓글을 달거나 삭제할 수 있는 ajax 댓글 시스템으로 교체하기
| ajax 댓글 플러그인 v1.0 | https://sir.kr/g5_plugin/4972 |
상기 그누보드 링크를 참고해서 수정하였다.
1. 그누보드5/eyoom/user_program/board/delete_comment.skin.php 파일을 열어 다음과 수정한다.
만약 delete_comment.skin.php 파일이 없다면 UTF-8(BOM 없음) 인코딩으로 만들어서 진행한다.
수정 전{code:php}
<?php
if (!defined('_GNUBOARD_')) exit;
// Your Program - Start
// Your Program - End
// 변수 할당하기 - /eyoom/inc/tpl.assign.php 파일 참조
$tpl->assign(array(
));
?>
{/code}수정 후{code:php}
<?php
if (!defined('_GNUBOARD_')) exit;
// Your Program - Start
delete_cache_latest($bo_table);
echo G5_HTTP_BBS_URL.'/board.php?bo_table='.$bo_table.'&wr_id='.$write['wr_parent'];
exit;
// Your Program - End
// 변수 할당하기 - /eyoom/inc/tpl.assign.php 파일 참조
$tpl->assign(array(
));
?>
{/code}
2. 그누보드5/eyoom/user_program/board/write_comment_update.skin.php 파일을 열어 다음과 수정한다.
만약 write_comment_update.skin.php 파일이 없다면 UTF-8(BOM 없음) 인코딩으로 만들어서 진행한다.
수정 전{code:php}
<?php
if (!defined('_GNUBOARD_')) exit;
// Your Program - Start
// Your Program - End
// 변수 할당하기 - /eyoom/inc/tpl.assign.php 파일 참조
$tpl->assign(array(
));
?>
{/code}수정 후{code:php}
<?php
if (!defined('_GNUBOARD_')) exit;
// Your Program - Start
delete_cache_latest($bo_table);
echo G5_HTTP_BBS_URL.'/board.php?bo_table='.$bo_table.'&wr_id='.$wr['wr_parent'].'#c_'.$comment_id;
exit;
// Your Program - End
// 변수 할당하기 - /eyoom/inc/tpl.assign.php 파일 참조
$tpl->assign(array(
));
?>
{/code}
3. ajax 댓글 시스템을 사용할 스킨 폴더에 view_comment.skin.html 파일을 열어 다음과 같이 수정한다.
① onclick="return comment_delete();" 을 검색하여 다음과 같이 수정한다.
수정 전{code:html}
onclick="return comment_delete();"
{/code}수정 후{code:html}
onclick="return comment_delete(this);"
{/code}
② <div class="view-comment"> 를 검색하여 다음과 같이 수정한다.
수정 전{code:html}
<div class="view-comment">
{/code} 수정 후{code:html}
<div class="view-comment">
<ajaxcomment>
{/code}
③ <!--{? eyoom_board.bo_use_cmt_infinite == '1'}--> 를 검색하여 다음과 같이 수정한다.
수정 전{code:html}
<!--{? eyoom_board.bo_use_cmt_infinite == '1'}-->
{/code}수정 후{code:html}
</ajaxcomment>
<!--{? eyoom_board.bo_use_cmt_infinite == '1'}-->
{/code}
④ document.getElementById("btn_submit").disabled = "disabled"; 를 검색하여 다음과 같이 수정한다.
수정 전{code:js}
document.getElementById("btn_submit").disabled = "disabled";
return true;
}
{/code}수정 후{code:js}
document.getElementById("btn_submit").disabled = "disabled";
// ajax comment system
$.ajax({
url: f.action,
type: 'POST',
data: $(f).serialize(),
dataType: 'html',
})
.done(function(str) {
var tempDom = $('<output>').append($.parseHTML(str))
var title = $('title', tempDom).text()
if (title === '') {
// 1. commentBox 원위치
comment_box('', 'c')
// 2. commentBox Form 리셋
f.reset()
// 3. 코멘트 출력
$.ajax({
url: str,
type: 'GET',
dataType: 'html'
})
.done(function(str2) {
var tempDom2 = $('<output>').append($.parseHTML(str2))
$('ajaxcomment').replaceWith($('ajaxcomment', tempDom2))
})
}
<?php if ($is_guest) { ?>
// 4. 캡차 리로드
$('#captcha_reload').trigger('click')
<?php } ?>
document.getElementById("btn_submit").disabled = ""
})
return false;
}
{/code}
⑤ function comment_delete() 를 검색하여 다음과 같이 수정한다.
수정 전{code:js}
function comment_delete()
{
return confirm("이 댓글을 삭제하시겠습니까?");
}
{/code}수정 후{code:js}
function comment_delete(that)
{
if (confirm('이 댓글을 삭제하시겠습니까?')) {
// ajax comment system
$.ajax({
url: that.href,
type: 'GET',
dataType: 'html',
})
.done(function(str) {
var tempDom = $('<output>').append($.parseHTML(str))
var title = $('title', tempDom).text()
if (title === '') {
// 1. commentBox 원위치
comment_box('', 'c')
// 2. 코멘트 출력
$.ajax({
url: str,
type: 'GET',
dataType: 'html'
})
.done(function(str2) {
var tempDom2 = $('<output>').append($.parseHTML(str2))
$('ajaxcomment').replaceWith($('ajaxcomment', tempDom2))
})
}
<?php if ($is_guest) { ?>
// 4. 캡차 리로드
$('#captcha_reload').trigger('click')
<?php } ?>
})
}
return false
}
{/code}
추천인 2
레벨 154
경험치 3,576,436
Progress Bar 91.21%
- 가입일 : 2015-03-10 12:21:44
- 서명 : 인간에게 가장 큰 선물은
자기 자신에게 기회를 주는 것이다.
- 크리스 가드너, Chris Gardner -
- 자기소개 : There's never a shortcut to happiness.
-
[좋은 생각] 자기를 아는 사람2026-02-02
-
[좋은 생각] 애쓰지 않고 편안하게2026-02-02
-
[좋은 생각] 천성적으로 타고나지 않았더라도 마음을 다해 내 것으로 만들 수 있는 것2026-02-02
-
[좋은 생각] 표를 세는 사람이 모든 것을 결정한다2026-02-02
-
[좋은 생각] 희망 도토리2026-02-02
-
[좋은 생각] 자유는 먹고사는 게 다 해결되고 나서야 시작됩니다2026-02-02
-
[생활 정보] [판매중] 햇반 윤기가득쌀밥 210g 24입 (1박스) (20,900원 / 무료)2026-02-02
-
[생활 정보] [판매중] 실속형 신고배 4.5kg 중대과(7-9과 내외) (10,740원 / 무료)2026-02-02
-
[생활 정보] 가격이 착하다 싶더니 할인이 사라지고 일반가 30,900원으로 판매하네요2026-01-28
-
[일일 메모장] 안타까운 소식입니다. 민주 진영의 거목이였던 이해찬 전 대표님 정말 고생 많으셨습니다. 이제 편히 쉬십시오.2026-01-25
-
[자유 게시판] 올 한 해도 잘 부탁드립니다. 새해 복 많이 받으세요.2026-01-06
-
[일일 메모장] 무슨 말이 필요할까요 삼가 조의를 표하며 고인의 명복을 빕니다 영면하세요2026-01-05
-
[생활 정보] 이번 년도도 잘 정리해 주셨네요 감사드립니다2026-01-01
-
[자유 게시판] 새해 맞기 전 마지막 날을 좀 더 멋지게 보내고 싶은데 늘 마음 뿐이네요 활기차고 신난 새해로 시작되시길 빌어요 올 한 해도 화이팅입니다2026-01-01
-
[자유 게시판] 메리 크리스마스 행복이 넘쳐 흘러 기쁨을 만끽하는 하루 그런 날 되세요2025-12-25
-
[자유 게시판] 1990년대를 살았던 우리들의 꽃피던 시절은 시끌벅쩍하고 그토록 화려했던 것 같습니다. 세상에 맞선 용기는 사라지고 조심성만 커져 버린 오늘의 삶이지만 어제보다 더 나은 오늘, 오늘 보다 더 나은 미래를 그리는 그런 삶을 그려 나가길 기원합니다. 메리 크리스마스! 행복한 성탄절되세요!!2025-12-24


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