1

我有带有 JS 滑块的菜单代码:

在 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标签中有这个菜单类。可能吗?

4

1 回答 1

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');
于 2013-03-20T11:28:59.397 回答