A

prototype.js 를 이용한 트리형식의 카테고리메뉴

· 17년 전 · 2407
도움이 될까 해서 올립니다.

이미지파일은 폴더형태의 열림/닫힘 을 구하셔서
열림(folderopen.gif),  닫힘(fiolder.gif) 으로 이름을 바꾸시고
_Images 디렉토리 안에 넣어두시면 바로 적용됩니다.

기본적으로 prototype.js 를 사용했으니 다운을 받으세요. 구하기 쉽습니다.

http://www.prototypejs.org/ 에서 받으시고 prototype.js 로 이름을 리네임하세요.

자바스크립트의 객체지향적 개발방법에 대한 기초적인 부분이고요
디비 연동 및 XML 연동 부분은 뭐 기회가 있다면 또 올려드리겠습니다...

초보분들 참고하세요...


<!-- category.html  부분 -->

<script type="text/javascript" src="prototype.js"></script>
<script type="text/javascript" src="CateGory.js"></script>

<div id="menu1" onClick="CateGory.SwitchCateGory('sub1', this)" style="cursor:pointer">
<img id="folder_menu1" align="absmiddle" src="_Images/folder.gif">아침식사</div>
     <span class="submenu" id="sub1" style="display:none;padding-left:10px">
            
        <div id="menu1-1" onClick="CateGory.SwitchCateGory('sub1-1', this)" style="cursor:pointer">
        <img id="folder_menu1-1" align="absmiddle" src="_Images/folder.gif">중간점검</div>
            <span class="submenu" id="sub1-1" style="display:none;padding-left:15px">
                <a href="#" onclick="CateGory.ClickMenu('컵라면')">컵라면</a><br>
                빵과 우유<br>
                삼겹살
            </span>
        박카스<br>
        십전대보탕<br>
        원숭이골탕
        </span>

<div id="menu2" onClick="CateGory.SwitchCateGory('sub2', this)" style="cursor:pointer">
<img id="folder_menu2" align="absmiddle" src="_Images/folder.gif">점심식사</div>
      <span class="submenu" id="sub2" style="display:none;padding-left:10px">
        콩나물 해장국<br>
        개구리 앞다리<br>
        바퀴벌레 수염튀김
        </span>

<div id="menu3" onClick="CateGory.SwitchCateGory('sub3', this)" style="cursor:pointer">
<img id="folder_menu3" align="absmiddle" src="_Images/folder.gif">저녁식사</div>
      <span class="submenu" id="sub3" style="display:none;padding-left:10px">
        물회<br>
        개구리 뒷다리<br>
        돼지 혀바닥 튀김
        </span>        



<!-- CateGory.js 부분 -->


var CateGory =
{

    UDIR         : '',    // 경로


    // 구성된 트리메뉴에서 클릭시 메뉴전환처리
       
    SwitchCateGory : function ( OBJ, F )
    {

        if ( document.getElementById )
        {
            var EL      = $(OBJ);                            // 현재 클릭한 메뉴의 객체
            var CHEL = EL.getElementsByTagName("span");    // 하위메뉴의 엘리먼트
                
            var HID  = $(F.id);                        // 현재 엘리먼트

            var divNimg = 'folder_' + HID.id;            // IMG 아이디를 생성시킴
            var ImgSrc     = $(divNimg).src;
                
            var imgClose = "folder.gif";                // 닫힘 아이콘
            var imgOpen  = "folderopen.gif";            // 열림 아이콘

            var    imgName     = imgOpen;                        // 기본은 닫힘

            var ImgFileName = ( imgName == 'folder.gif' ) ?  imgOpen : imgClose;    // 상황에 따라 열림/닫힘                    
            var imgPath  = "<img id='"+divNimg+"' align='absmiddle' src='"+this.UDIR+"/_Images/"+ImgFileName+"'>";                    

                
            if ( EL.style.display != "block" )    { EL.style.display = "block"; }
            else                                { EL.style.display = "none"; }

        }

    }
        
}        


더 좋은 방법이나 좋은프로그램 있으면 올려주세요.. 저도 참고 좀 하게~~^^
[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
17년 전 조회 1,873
17년 전 조회 2,925
17년 전 조회 1,890
17년 전 조회 1,459
17년 전 조회 1,614
17년 전 조회 3,526
17년 전 조회 2,556
17년 전 조회 2,348
17년 전 조회 1,595
17년 전 조회 2,832
17년 전 조회 1,546
17년 전 조회 1,516
17년 전 조회 1,779
17년 전 조회 3,125
17년 전 조회 2,786
17년 전 조회 2,874
17년 전 조회 1,571
17년 전 조회 1,691
17년 전 조회 3,646
17년 전 조회 3,218
17년 전 조회 4,486
17년 전 조회 2,646
17년 전 조회 2,755
17년 전 조회 1,802
17년 전 조회 2,900
17년 전 조회 2,600
17년 전 조회 3,364
17년 전 조회 2,860
17년 전 조회 2,023
17년 전 조회 2,803
17년 전 조회 1,948
17년 전 조회 1,547
17년 전 조회 2,621
17년 전 조회 3,244
17년 전 조회 4,444
17년 전 조회 3,521
17년 전 조회 1,793
17년 전 조회 2,003
17년 전 조회 2,599
17년 전 조회 1,910
17년 전 조회 2,102
17년 전 조회 3,057
17년 전 조회 2,507
17년 전 조회 2,152
17년 전 조회 4,570
17년 전 조회 3,379
17년 전 조회 1,791
17년 전 조회 3,915
17년 전 조회 3,165
17년 전 조회 2,408
17년 전 조회 1,669
17년 전 조회 2,684
17년 전 조회 2,406
17년 전 조회 2,349
17년 전 조회 2,288
17년 전 조회 1,519
17년 전 조회 2,221
17년 전 조회 3,268
17년 전 조회 1,764
17년 전 조회 2,026
17년 전 조회 1,694
17년 전 조회 1,940
17년 전 조회 1,916
17년 전 조회 1,819
17년 전 조회 2,904
17년 전 조회 2,669
17년 전 조회 2,460
17년 전 조회 1,755
17년 전 조회 2,784
17년 전 조회 4,591
17년 전 조회 3,079
17년 전 조회 2,004
17년 전 조회 2,193
17년 전 조회 3,606
17년 전 조회 2,592
17년 전 조회 4,157
17년 전 조회 2,006
17년 전 조회 2,600
17년 전 조회 2,442
17년 전 조회 1,964
17년 전 조회 2,468
17년 전 조회 2,281
17년 전 조회 2,316
17년 전 조회 3,430
17년 전 조회 2,495
17년 전 조회 1,774
17년 전 조회 1,797
17년 전 조회 2,460
17년 전 조회 3,543
17년 전 조회 2,464
17년 전 조회 1,881
17년 전 조회 4,586
17년 전 조회 2,365
17년 전 조회 3,802
17년 전 조회 6,374
17년 전 조회 1,833
17년 전 조회 1,992
17년 전 조회 1,566
17년 전 조회 1,685
17년 전 조회 3,211