2013-03-20 3 views
1

내가 JS 슬라이더와 메뉴 코드가 : HTML에서자바 스크립트 초기화 + HTML5 태그

:

window.onload = function() { 
    menuSlider.init('nav', 'slide'); 
} 

<nav> 
    <ul> 
     <li value="1"><a href="">Link</a></li> 
     <li><a href="">Link</a></li> 
     <li><a href="">Link</a></li> 
    </ul> 
    <div id="slide"></div> 
</nav> 

JS :

var menuSlider=function(){ 
    var m,e,g,s,q,i; e=[]; q=8; i=8; 
return{ 
    init:function(j,k){ 
     m=document.getElementById(j); e=m.getElementsByTagName('li'); 
     var i,l,w,p; i=0; l=e.length; 
     for(i;i<l;i++){ 
      var c,v; c=e[i]; v=c.value; if(v==1){s=c; w=c.offsetWidth; p=c.offsetLeft} 
      c.onmouseover=function(){menuSlider.mo(this)}; c.onmouseout=function(){menuSlider.mo(s)}; 
     } 
     g=document.getElementById(k); g.style.width=w+'px'; g.style.left=p+'px'; 
    }, 
    mo:function(d){ 
     clearInterval(m.tm); 
     var el,ew; el=parseInt(d.offsetLeft); ew=parseInt(d.offsetWidth); 
     m.tm=setInterval(function(){menuSlider.mv(el,ew)},i); 
    }, 
    mv:function(el,ew){ 
     var l,w; l=parseInt(g.offsetLeft); w=parseInt(g.offsetWidth); 
     if(l!=el||w!=ew){ 
      if(l!=el){var ld,lr,li; ld=(l>el)?-1:1; lr=Math.abs(el-l); li=(lr<q)?ld*lr:ld*q; g.style.left=(l+li)+'px'} 
      if(w!=ew){var wd,wr,wi; wd=(w>ew)?-1:1; wr=Math.abs(ew-w); wi=(wr<q)?wd*wr:wd*q; g.style.width=(w+wi)+'px'} 
     }else{clearInterval(m.tm)} 
}};}(); 

orginal 한 코드에서를 <ul class="menu">menuSlider.init('menu', 'slide'); 내 질문이 있었다 단지 'nav' 태그로이 스크립트를 초기화하는 방법입니까? 내 ul 태그에이 메뉴 클래스를 갖고 싶지 않습니다. 가능한가? 아마도

답변

0

당신이 5 행 변경 한 경우 작동합니다 :

m=document.getElementById(j); e=m.getElementsByTagName('li'); 

//       your preferred element here | 
//              V 
m=document.getElementById(j); e=m.getElementsByTagName('div'); 

이 그런 다음 HTML 따라 CSS를 업데이트를 ...

<div id="nav"> 
    <div>Item One</div> 
    <div>Item Two</div> 
    <div>etc. </div> 
</div> 

갱신 : 무엇을 ...에 대한

m=document.getElementsByTagName(j)[0]; e=m.getElementsByTagName('li'); 
+0

하지만 저는 'ul'과 'li'을 유지하고 싶지만이 스크립트를 초기화하십시오. vi 어떤 클래스 나 id도없는 'nav'태그 – Krzy

+0

@Krzy 오, 죄송합니다. 기본적으로 init ('nav', 'slide')를 사용하면 첫 번째 요소 만 가져옵니다. – Emissary

+0

지금이 'menuSlider.init ('메뉴 ','슬라이드 ')'와 '

어떻게 클래스 또는 ID없이이 UL를 얻을 수 있습니까? – Krzy