웹마스터 팁

새글 옆에는 new 표시가 뜨는데, 게시판에는 안 뜨셔서 답답하셨던 분 계시죠?

제가 php도 모르고, 자바스크립트도 잘 모르고, 더군다나 데이터베이스도 거의 모릅니다.

더 심각한건 XE를 다룬지는 고작 3~4일 됐습니다.

그래서 하찮게 들릴 수도 있으니 진짜 초보이고 급하신 분들만 참고하세요.

 

약간 꼼수인데요. 레이아웃 html에서 바로 소스 추가하였습니다.

 

<?php

//데이터 베이스에서 등록된 글 정보를 가져옵니다.
$result = @mysql_query('SELECT * FROM `xe_documents`');
//time interval을 계산합니다.

$time_interval = 86400;
$time_check = date("YmdHis", time()-$time_interval);

//가져온 글 정보 중에 모듈 번호와 등록시간을 배열에 집어 넣습니다.
while($row = @mysql_fetch_array($result)){
$module_srl[] = $row[module_srl];
$regdate[] = $row[regdate];
}

//가져온 데이터 개수를 셉니다.
$regdate_len = count($regdate);
?>

 

<script type="text/javascript">

    var module_srl = new Array();
    var regdate = new Array();

//php에서 가져온 값을 자바스크립트에서 사용하기 위해 자바스크립트 변수에 담습니다.

//최근값을 체크하는 것이므로 실제 받아온 값의 역순으로 넣어야 나중에 비교 회수가 줄어듭니다.
    <?php
        echo "regdate_len = $regdate_len;";
        echo "time_check = $time_check;";
        for($i=0;$i<$regdate_len;$i++){
            $j = $regdate_len-$i-1;
            echo "module_srl[$i] = $module_srl[$j];";
            echo "regdate[$i] = $regdate[$j];";
        }
    ?>

//제가 XE의 구조를 잘 모릅니다. 그래서 꼼수를 부렸습니다.

//대충 보니까 아래에서 게시판 정보를 가져오더라구요.

//       <!--@foreach($val['list'] as $key1 => $val1)--> <!--@if($val1['text'])-->
//         y=y+1; board="{$val1['href']}";
//             <!--@if($val1['selected']) -->
//             cnt=y;
//             <!--@end-->

//"{$val['href']}" 에  /?mid=test_board 와 같은 모듈 이름이 저장되어 있길래 board 변수에 저장했습니다.

//module_srl 번호가 직접 저장돼 있는 곳이 있을지도 모르는데, 아무튼 저는 모릅니다ㅠㅠ

//구조를 정확히 아신다면 그냥 그거 갖다 쓰시면 되겠습니다ㅠㅠ

 

//새글이 등록된 게시판 체크하는 함수입니다.
function new_icon(board){
    var board_id;

//가져온 board 변수의 /?mid=test_board 값에 test_board가 있는지 체크하고

//있으면 그 board의 module_srl 값을 board_id에 넣습니다.
    if(board.search("notice_board") != -1) board_id = '100';
    if(board.search("humor_board") != -1) board_id = '200';
    if(board.search("test_board") != -1) board_id = '300';

//만약 DB에서 가져 온 데이터의 module_srl 값과 board_id와 같다면

//regdate가 time_check보다 큰지 비교하고 크다면 true 값을 리턴합니다.

//만약 아니라면 false값을 리턴합니다.

//보드 값을 찾지 못했다면 false를 리턴합니다.
    for(i=0;i<regdate_len;i++){
        if(module_srl[i] == board_id) {
            if(regdate[i] > time_check) {
                return true;
            }
            else {
                return false;
            }
        }
    }
    return false;
};

 

이렇게 새글이 등록된 보드를 골라내었습니다.

예로 제가 사용한 메뉴를 보여드리겠습니다.

 

//저는 dTree 메뉴를 사용하고 있습니다.

//빨갛게 표시한 부분에 파라미터로 true / false 값을 받도록 해줍니다.

 d.add(y,x,new_icon(board),"{$val1['link']}","{$val1['href']}",''<!--@if($val1['open_window']=='Y')-->,true<!--@end-->);

 

그리고 dTree.js 자바스크립트 파일 내용을 조금 수정하였습니다.

//이 부분처럼 함수 정의 부분에서 파라미터를 하나 더 추가하였습니다.

function Node(id, pid, new_icon, name, url, title, target, icon, iconOpen, open)

//그리고 실제 메뉴를 구성하는 부분에서 new_icon의 true /false 여부에 따라 아이콘 출력 여부를 결정하였습니다.

 str += node.name;
 if(node.new_icon) str += ' <img src="./뉴아이콘이미지경로>'

 

실제 적용 스크린샷 첨부합니다.

파란 하트로 표시된 게시판에 새글이 등록된 상태입니다.

 example.jpg  



저 같은 초보 분만 참고해주시구요.

고수님들은 그냥 넘어가주세요~ 하하~

아예 모듈화 해주실 고수분 계시면 좋겠습니다^^

제목 글쓴이 날짜
모바일에서 레벨 아이콘, 이미지 아이콘 표시하기 [4] Gunmania 2013.08.23
1전 짜리 팁 - 최근수정일 표시 [2] 지그재거 2013.08.22
XE 알림센터 스킨을 iOS 알림창 비슷하게 만들기 [2] file novelic 2013.08.21
간단하게 사용자가 에디터 바꿔쓸 수 있도록 하기 ^^ [6] file Xiso 2013.08.20
jQuery fadeIn 홈페이지 부드럽게 이동 [4] file 지그재거 2013.08.20
리퍼러 수집기 애드온 실행후 사이트 먹통되었을때 대처법 [2] serendip 2013.08.19
탈퇴회원 레벨 아이콘 출력 안하기 [7] Gunmania 2013.08.17
벼랑끝 font awesome 45도를 아시나요 ? [2] file 지그재거 2013.08.13
[1.7.4] 로그인창 옆에 신규 쪽지 수 보여주기 socialskyo 2013.08.13
게시판 댓글 스킨에서 추가적인 변수 전달 안 되는 현상 보완 위해서. [1] sejin7940 2013.08.11
여러장의 이미지 동시 삽입시 이미지 간격조정 팁 [3] 꿈섬 2013.08.10
[주옥시리즈]닉네임/이메일 변경 금지 팁 [10] socialskyo 2013.08.10
스크롤 맨아래로 내리면 자동으로 글 목록 더보이기 구현(게시판어어느 스킨이든 사용가능) [19] 장포크 2013.08.10
지식인 모바일에서 답변이 보이지 않는 현상. 씨즈부스 2013.08.10
최신 제로보드 XE 동영상 강의 [25] 하얀마법 2013.08.09
새로고침없이 페이지 리로딩 간단하고 쉽게 서버한테는 미안하게 하는법 (서버단이 아니고 스킨에 ㅠ jquery load씀) 게시글,댓글,추천등 모든 부분다가능합니다. [2] 장포크 2013.08.08
textarea 테그 제임스라 2013.08.07
1.7.3.4 + sketchbook5 에서 대댓글 에디터 사용불가문제 [4] 뒤뒤 2013.08.07
익명게시판에서 회원 구분 가능하게 + 각 게시물에서 다른 아이디가 나타나게 하는 방법 [3] jn4kim 2013.08.06
HTML5를 이용한 시멘틱 XE 레이아웃 만들기 (인트로) [3] 이온디 2013.08.04