1
我與JS滑塊菜單代碼:的JavaScript初始化+ HTML5標籤
在HTML:
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)}
}};}();
用原代碼有一個<ul class="menu">
和menuSlider.init('menu', 'slide');
我的問題如何使用'nav'
標籤初始化此腳本?我不想在我的ul
標記中使用此菜單類。可能嗎?
但是我想留'ul'和'li',但是初始化這個腳本vi沒有任何課程或ID的'nav'標籤 – Krzy 2013-03-20 11:32:40
@Krzy哦,對不起,我現在得到你 - 更新。基本上,如果你只有init('nav','slide')',那麼它將抓住第一個元素。 – Emissary 2013-03-20 11:37:25
我現在有: 'menuSlider.init(' 菜單 ' '滑')' 和'如何獲取UL沒有class和id? – Krzy 2013-03-20 11:48:23