諮詢

2012-08-10 82 views
1

所以,我有下面的代碼片段:諮詢

Script.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.onclick=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)} 
}};}(); 

-

style2.css- 
... 
#slide {position:absolute; top:6px; height:13px; background:#4A7AFF; z-index:10} 

我調用JavaScript從我的HTML文件以相當標準的方式:

... 
script type="text/javascript" language="javascript" src="script.js"></script> 
</head> 
<body onload="global.menuSlider.init('menu','slide')"> 
... 

基本上,我想嘗試調用這個滑塊的幾個實例在我的HTML文檔中。我已經試過包裝另一個函數裏面的函數:

(var global=function() {var menuSlider=function(){...}};}();}());\ 

,然後調用全局函數,而不是menuSlider功能(試圖按照給定的here建議,但沒有運氣(沒有工作,很明顯)

這是怎麼了,我從index.html的調用它。

<script type="text/javascript" language="javascript" src="script.js"></script> 
</head> 
<body onload="menuSlider.init('menu','slide')"> 
<div class="menu"> 
    <ul id="menu"> 
     <li value="1"><a style="cursor:pointer">1</a></li> 
     <li value="2"><a style="cursor:pointer">2</a></li> 
     <li value="3"><a style="cursor:pointer">3</a></li> 
     <li value="4"><a style="cursor:pointer">4</a></li> 
     <li value="5"><a style="cursor:pointer">5</a></li> 
     <li value="6"><a style="cursor:pointer">6</a></li> 
    </ul> 
    <div id="slide"></div> 
</div> 

當我說這不是工作,我的意思是,如果我嘗試調用函數兩次(EG:

<div class="menu"> 
    <ul id="menu"> 
     <li value="1"><a style="cursor:pointer">1</a></li> 
     <li value="2"><a style="cursor:pointer">2</a></li> 
     <li value="3"><a style="cursor:pointer">3</a></li> 
     <li value="4"><a style="cursor:pointer">4</a></li> 
     <li value="5"><a style="cursor:pointer">5</a></li> 
     <li value="6"><a style="cursor:pointer">6</a></li> 
    </ul> 
    <div id="slide"></div> 
</div><div class="menu"> 
    <ul id="menu"> 
     <li value="1"><a style="cursor:pointer">1</a></li> 
     <li value="2"><a style="cursor:pointer">2</a></li> 
     <li value="3"><a style="cursor:pointer">3</a></li> 
     <li value="4"><a style="cursor:pointer">4</a></li> 
     <li value="5"><a style="cursor:pointer">5</a></li> 
     <li value="6"><a style="cursor:pointer">6</a></li> 
    </ul> 
    <div id="slide"></div> 
</div> 

滑動條和數值的背景出現了兩次,但滑桿(讀:滑塊)的實際功能部分僅適用第一欄上(和它不能很好地工作)。

我想我只調用一次函數,或者,如果我多次調用它,也許我會調用函數的兩個實例在對方之上?

+0

如果您發佈您的代碼調用menuSlider這將有助於。另外,出了什麼問題?你是否收到錯誤信息? – 2012-08-10 19:54:02

+0

@AaronKurtzhals我剛剛更新了我的問題,並提供了您要求的信息,謝謝! – gfppaste 2012-08-13 17:43:33

回答

1

在HTML中,id屬性必須是唯一的。嘗試

<div class="menu"> 
    <ul id="menuA"> 
     <li value="1"><a style="cursor:pointer">1</a></li> 
     <li value="2"><a style="cursor:pointer">2</a></li> 
     <li value="3"><a style="cursor:pointer">3</a></li> 
     <li value="4"><a style="cursor:pointer">4</a></li> 
     <li value="5"><a style="cursor:pointer">5</a></li> 
     <li value="6"><a style="cursor:pointer">6</a></li> 
    </ul> 
    <div id="slideA"></div> 
</div><div class="menu"> 
    <ul id="menuB"> 
     <li value="1"><a style="cursor:pointer">1</a></li> 
     <li value="2"><a style="cursor:pointer">2</a></li> 
     <li value="3"><a style="cursor:pointer">3</a></li> 
     <li value="4"><a style="cursor:pointer">4</a></li> 
     <li value="5"><a style="cursor:pointer">5</a></li> 
     <li value="6"><a style="cursor:pointer">6</a></li> 
    </ul> 
    <div id="slideB"></div> 
</div> 

在你的JavaScript:

window.onload = function() { 
    menuSlider.init('menuA','slideA'); 
    menuSlider.init('menuB','slideB'); 
}; 
+0

這很完美,謝謝! – gfppaste 2012-08-14 13:05:10