所以,我有以下代码片段:
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}
我以非常标准的方式从我的 HTML 文档中调用 javascript:
...
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 函数(尝试遵循此处给出的建议,但没有运气(显然没有工作)。
这就是我从 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>
当我说它不起作用时,我的意思是如果我尝试调用该函数两次(例如:
<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>
滑动条的背景和数值出现了两次,但滑动条的实际功能部分(读作:滑块)只在第一个条上有效(而且效果不佳)。
我想我只调用一次函数,或者,如果我不止一次调用它,也许我正在调用函数的两个实例?