[HTML] 부드럽게 서브메뉴가 슬라이딩 되는 펼침메뉴

<html>
<head>
    <title>http://siteweb.co.kr/</title>
<script language="javascript">
/**
* by 행복한고니 (20041008)
*
* Homepage : http://siteweb.co.kr/
*/
<!--
function slide(Id, interval, to) {
    var obj = document.getElementById(Id);
    var H, step = 5;

    if (obj == null) return;
    if (to == undefined) { // user clicking
        if (obj._slideStart == true) return;
        if (obj._expand == true) {
            to = 0;
            obj.style.overflow = "hidden";
        } else {
            slide.addId(Id);
            for(var i=0; i < slide.objects.length; i++) {
                if (slide.objects[i].id != Id && slide.objects[i]._expand == true) {
                    slide(slide.objects[i].id);
                }
            }

            obj.style.height = "";
            obj.style.overflow = "";
            obj.style.display = "block";
            to = obj.offsetHeight; // 이거이거
            obj.style.overflow = "hidden";
            obj.style.height = "1px";
        }
        obj._slideStart = true;
    }
   
    step            = ((to > 0) ? 1:-1) * step;
    interval        = ((interval==undefined)?1:interval);

    obj.style.height = (H=((H=(isNaN(H=parseInt(obj.style.height))?0:H))+step<0)?0:H+step)+"px";
   
   
    if (H <= 0) {
        obj.style.display = "none";
        obj.style.overflow = "hidden";
        obj._expand = false;
        obj._slideStart = false;
    } else if (to > 0 && H >= to) {
        obj.style.display = "block";
        obj.style.overflow = "visible";
        obj.style.height = H + "px";
        obj._expand = true;
        obj._slideStart = false;
    } else {
        setTimeout("slide('"+Id+"' , "+interval+", "+to+");", interval);
    }
}
slide.objects = new Array();
slide.addId = function(Id)
{
    for (var i=0; i < slide.objects.length; i++) {
        if (slide.objects[i].id == Id) return true;
    }
    slide.objects[slide.objects.length] = document.getElementById(Id);
}
//-->
</script>

<style>
.menu {
    border:1px solid #999999;
    background-color:#FFCC00;
    padding:3px 1px 1px 5px;
    cursor:hand;
    width:150px;
}
.submenu {
    width:150px;
    padding-left:10px;
    display:none;
}
</style>
</head>
<body>

<div class="menu" onClick="slide('sub1');">메뉴항목 1</div>
<div id="sub1" class="submenu">
    <div>- Sub menu 1-1</div>
    <div>- Sub menu 1-2</div>
    <div>- Sub menu 1-3</div>
    <div>- Sub menu 1-4</div>
    <div>- Sub menu 1-5</div>
</div>
<div class="menu" onClick="slide('sub2');">메뉴항목 2</div>
<div id="sub2" class="submenu">
    <div>- Sub menu 2-1</div>
    <div>- Sub menu 2-2</div>
    <div>- Sub menu 2-3</div>
    <div>- Sub menu 2-4</div>
    <div>- Sub menu 2-5</div>
    <div>- Sub menu 2-6</div>
    <div>- Sub menu 2-7</div>
    <div>- Sub menu 2-8</div>
</div>
<div class="menu" onClick="slide('sub3');">메뉴항목 3</div>
<div id="sub3" class="submenu">
    <div>- Sub menu 3-1</div>
    <div>- Sub menu 3-2</div>
    <div>- Sub menu 3-3</div>
</div>
<div class="menu" onClick="slide('sub4');">메뉴항목 4</div>
<div id="sub4" class="submenu">
    <div>- Sub menu 4-1</div>
    <div>- Sub menu 4-2</div>
    <div>- Sub menu 4-3</div>
</div>
<div class="menu" onClick="slide('sub5');">메뉴항목 5</div>
<div id="sub5" class="submenu">
    <div>- Sub menu 5-1</div>
    <div>- Sub menu 5-2</div>
    <div>- Sub menu 5-3</div>
    <div>- Sub menu 5-4</div>
</div>

</body>
</html>

[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]
|

댓글 3개

잘쓸게요.
세로메뉴네요. 감사합니다.
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
17년 전 조회 2,943
17년 전 조회 2,879
17년 전 조회 1,610
17년 전 조회 1,252
17년 전 조회 3,956
17년 전 조회 1,628
17년 전 조회 1,620
17년 전 조회 2,123
17년 전 조회 1,893
17년 전 조회 1,508
17년 전 조회 3,927
17년 전 조회 1,765
17년 전 조회 3,139
17년 전 조회 3,018
17년 전 조회 1,050
17년 전 조회 1,859
17년 전 조회 1,604
17년 전 조회 1,860
17년 전 조회 2,652
17년 전 조회 3,034
17년 전 조회 3,227
17년 전 조회 3,337
17년 전 조회 1,472
17년 전 조회 1,428
17년 전 조회 2,264
17년 전 조회 1,988
17년 전 조회 2,301
17년 전 조회 2,827
17년 전 조회 3,276
17년 전 조회 2,373
17년 전 조회 1,644
17년 전 조회 3,216
17년 전 조회 3,080
17년 전 조회 3,056
17년 전 조회 3,925
17년 전 조회 2,598
17년 전 조회 2,419
17년 전 조회 2,668
17년 전 조회 2,906
17년 전 조회 2,622
17년 전 조회 1,465
17년 전 조회 1,909
17년 전 조회 1,500
17년 전 조회 1,923
17년 전 조회 2,523
17년 전 조회 8,704
17년 전 조회 3,164
17년 전 조회 4,256
17년 전 조회 1,991
17년 전 조회 3,671
17년 전 조회 1,565
17년 전 조회 1,397
17년 전 조회 2,331
17년 전 조회 1,328
17년 전 조회 1,644
17년 전 조회 1,476
17년 전 조회 2,543
17년 전 조회 1,511
17년 전 조회 1,101
17년 전 조회 1,233
17년 전 조회 3,111
17년 전 조회 2,174
17년 전 조회 1,982
17년 전 조회 1,226
17년 전 조회 2,456
17년 전 조회 1,180
17년 전 조회 1,139
17년 전 조회 1,387
17년 전 조회 2,751
17년 전 조회 2,402
17년 전 조회 2,491
17년 전 조회 1,191
17년 전 조회 1,310
17년 전 조회 3,254
17년 전 조회 2,840
17년 전 조회 4,108
17년 전 조회 2,270
17년 전 조회 2,366
17년 전 조회 1,418
17년 전 조회 2,537
17년 전 조회 2,221
17년 전 조회 2,979
17년 전 조회 2,489
17년 전 조회 1,650
17년 전 조회 2,443
17년 전 조회 1,601
17년 전 조회 1,188
17년 전 조회 2,248
17년 전 조회 2,894
17년 전 조회 4,071
17년 전 조회 3,159
17년 전 조회 1,426
17년 전 조회 1,710
17년 전 조회 2,252
17년 전 조회 1,561
17년 전 조회 1,736
17년 전 조회 2,726
17년 전 조회 2,152
17년 전 조회 1,806
17년 전 조회 4,212
🐛 버그신고