关于如何在同一页面上多次调用javascript函数的建议

关于如何在同一页面上多次调用javascript函数的建议,javascript,multiple-instances,Javascript,Multiple Instances,因此,我有以下代码片段: 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++)

因此,我有以下代码片段:

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)}
}};}();
我以一种非常标准的方式从HTML文档调用javascript:

...
script type="text/javascript" language="javascript" src="script.js"></script>
</head>
<body onload="global.menuSlider.init('menu','slide')">
...
然后调用全局函数而不是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>

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
当我说它不工作时,我的意思是如果我尝试调用该函数两次(例如:


  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
滑块的背景和数值显示两次,但滑块的实际功能部分(读取:滑块)仅在第一个条上工作(并且工作不正常)


我会想象我只调用一次函数,或者,如果我不止一次地调用它,可能我调用的是两个相互重叠的函数实例?

听起来你想要一个更像类的东西,从中可以实例化更多的实例


这个怎么样?

在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>

如果你发布调用menuSlider的代码会有帮助。还有,出了什么问题?你收到错误消息了吗?@AaronKurtzhals我刚刚用你要求的信息更新了我的问题,谢谢!这肯定让我走上了正确的轨道,非常感谢你的资源!
<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>
<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>
window.onload = function () {
     menuSlider.init('menuA','slideA');
     menuSlider.init('menuB','slideB');
};