자바스크립으로 플래쉬 메뉴처럼

톡박에 한번 올렸던 소스인데 조금 다듬어서 올립니다.
적절히 수정&가공하시면 멋진 메뉴가 나올거에요~

<html>
 <head>
  <title>Menu</title>
 </head>
<script>
var delay = 3;            // 메뉴 스피드(낮을수록 빠름)
var m_length = 20;    // 메뉴 간격
var sel_l_length = 30;    // 선택한 메뉴와 이전 메뉴 간격
var sel_r_length = 60;    // 선택한 메뉴와 다음 메뉴 간격


var m_sel = 0;            // 메뉴 선택 상태
var m_max = 0;        // 메인메뉴 갯수
var sm_alpha = 0;    // 서브메뉴 투명도
var id = new Array();    // 메인메뉴 ID
var sid = new Array();    // 서브메뉴 ID
var m_top = 0;                // 메인메뉴 y 위치
function on_load(){
    while(document.getElementById("menu"+(m_max+1)) != null){
        m_max++;
        id[m_max] = document.getElementById("menu"+m_max);
        sid[m_max] = document.getElementById("smenu"+m_max);
    };
    m_top = id[1].offsetTop;
    m_act();
}
function m_over(m){
    m_sel = m;
    for(i=1;i<=m_max;i++){
        if(sid[i] != null){
            if(m_sel == i){
                id[i].style.fontWeight = 'bold';
                sid[i].style.display = "";
                sm_alpha = 0;
                if ((navigator.appName.indexOf('Microsoft')+1)) {
                    sid[i].filters.alpha.opacity = sm_alpha;
                }else{
                    sid[i].style.opacity = (sm_alpha/100);
                }
                sid[i].style.top = id[i].offsetTop + id[i].offsetHeight + 40;
            }else{
                id[i].style.fontWeight = '';
                sid[i].style.display = "none";
            }
        }
    }
}
function m_act(){
    var goy = 0;
    for(i=1;i<=m_max;i++){

        // 메인메뉴 좌우 이동
        if(i>1)
            temp = id[i-1].offsetWidth + id[i-1].offsetLeft;
        if(i==1){
            gox=id[i].offsetLeft;
        }else if(m_sel == i){
            gox =  temp + sel_l_length;
        }else if(m_sel+1 == i){
            gox =temp + sel_r_length;
        }else{
            gox = temp + m_length;
        }
        id[i].style.left = Math.ceil(id[i].offsetLeft - (id[i].offsetLeft - (gox))/delay)+"px";

        // 메인메뉴 상하 이동
        if(m_sel == i){
            id[i].style.top = Math.ceil(id[i].offsetTop - (id[i].offsetTop - (m_top + 7))/delay)+"px";
        }else if(m_sel!=0){
            id[i].style.top = Math.ceil(id[i].offsetTop - (id[i].offsetTop - (m_top - 5))/delay)+"px";
        }

        // 서브메뉴
        if(m_sel == i && sid[i] != null){
            // 서브메뉴 투명도
            if(sm_alpha < 100){
                sm_alpha += 5;
                if ((navigator.appName.indexOf('Microsoft')+1)) {
                    sid[i].filters.alpha.opacity = sm_alpha;
                }else{
                    sid[i].style.opacity = (sm_alpha/100);
                }
            }
            // 서브메뉴 아래서부터 위로 나타남
            goy = id[i].offsetTop + id[i].offsetHeight;
            sid[i].style.top = (sid[i].offsetTop - (sid[i].offsetTop - goy)/delay)+"px";
        }
    }
    setTimeout('m_act()',20);
}

</script>
<style>
.sm_a{color: #666666; text-decoration:none; padding:0px 3px 0px 2px}
.sm_a:hover {color: #FFFFFF; text-decoration:none; background:#666666; padding:0px 3px 0px 2px}
div{font-family:verdana; font-size:10px; letter-spacing:-1px}
.smenu{top:50px; position:absolute; filter:alpha(opacity=0); color:#DDDDDD}
.mmenu{top:30px; position:absolute; cursor:pointer; padding-right:2px; color:#666666}
</style>
<body onload='on_load()'>
    <div class=mmenu style='left:200px;' id=menu1 onClick='m_over(1)'>
    ABOUT US<br>
    </div>
    <div id='smenu1' class=smenu style='left:200px; display:none'><a href='' class=sm_a>menu1</a> | <a href='' class=sm_a>menu2</a> | <a href='' class=sm_a>menu3</a></div>
    <div class=mmenu style='left:280px;' id=menu2 onClick='m_over(2)'>
    PRODUCT<br>
    </div>
    <div id='smenu2' class=smenu style='left:250px; display:none'><a href='' class=sm_a>menu4</a> | <a href='' class=sm_a>menu5</a> | <a href='' class=sm_a>menu6</a></div>
    <div class=mmenu style='left:360px;' id=menu3 onClick='m_over(3)'>
    STORY<br>
    </div>
    <div id='smenu3' class=smenu style='left:310px; display:none'><a href='' class=sm_a>menu7</a> | <a href='' class=sm_a>menu8</a> | <a href='' class=sm_a>menu9</a></div>
</body>
</html>
[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]
|

댓글 10개

우왓 ~ 고맙습니다. 지금 혼자 끙끙대던 건데^^
우아~이거 최곤데요
와우 멋진데요 감사 합니다
정말 좋네요 감사합니다.
블루비 자료와 같은데..요?
플레시메뉴처럼
감사합니다^^

멋지네요 - ㅎㅎㅎ
좋네요!! 추천한방^^
와,이거 정말 필요했었는데..감사합니다 ^^
정말이지 자바스크립트의 무한한가능성을 다시 한번 되새겨봅니다.
정말 대단하시네요~ 감탄했습니다.
정말 수고많으셨습니다. 새해 복 많이받으세요^^
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
18년 전 조회 3,486
18년 전 조회 1,676
18년 전 조회 3,448
18년 전 조회 2,026
18년 전 조회 5,295
18년 전 조회 2,157
18년 전 조회 2,341
18년 전 조회 1,736
18년 전 조회 2,141
18년 전 조회 3,654
18년 전 조회 1,509
18년 전 조회 1,741
18년 전 조회 4,324
18년 전 조회 3,716
18년 전 조회 3,274
18년 전 조회 3,376
18년 전 조회 3,874
18년 전 조회 4,335
18년 전 조회 4,261
18년 전 조회 2,709
18년 전 조회 2,327
18년 전 조회 3,261
18년 전 조회 3,173
18년 전 조회 3,330
18년 전 조회 3,265
18년 전 조회 4,924
18년 전 조회 5,212
18년 전 조회 3,418
18년 전 조회 2,719
18년 전 조회 2,953
18년 전 조회 2,282
18년 전 조회 2,091
18년 전 조회 2,040
18년 전 조회 3,073
18년 전 조회 2,361
18년 전 조회 2,382
18년 전 조회 2,055
18년 전 조회 2,432
18년 전 조회 3,163
18년 전 조회 4,097
18년 전 조회 3,377
18년 전 조회 2,012
18년 전 조회 1,956
18년 전 조회 2,867
18년 전 조회 1,666
18년 전 조회 2,013
18년 전 조회 2,307
18년 전 조회 2,168
18년 전 조회 2,269
18년 전 조회 4,040
18년 전 조회 1,791
18년 전 조회 4,391
18년 전 조회 2,925
18년 전 조회 2,234
18년 전 조회 3,276
18년 전 조회 2,899
18년 전 조회 2,837
18년 전 조회 5,632
18년 전 조회 2,298
18년 전 조회 3,419
18년 전 조회 3,328
18년 전 조회 3,715
18년 전 조회 3,267
18년 전 조회 2,446
18년 전 조회 2,096
18년 전 조회 2,546
18년 전 조회 6,114
18년 전 조회 2,737
18년 전 조회 4,543
18년 전 조회 2,039
18년 전 조회 1만
18년 전 조회 2,488
18년 전 조회 1,552
18년 전 조회 2,986
18년 전 조회 2,928
18년 전 조회 2,824
18년 전 조회 2,141
18년 전 조회 2,321
18년 전 조회 2,872
18년 전 조회 2,964
18년 전 조회 4,130
18년 전 조회 6,117
18년 전 조회 2,056
18년 전 조회 2,192
18년 전 조회 1,897
18년 전 조회 1,659
18년 전 조회 2,632
18년 전 조회 1,689
18년 전 조회 1,561
18년 전 조회 4,736
18년 전 조회 1,789
18년 전 조회 1,842
18년 전 조회 1,849
18년 전 조회 1,977
18년 전 조회 3,628
18년 전 조회 1,655
18년 전 조회 1,526
18년 전 조회 1,357
18년 전 조회 1,861
18년 전 조회 1,910
🐛 버그신고