1

我有一个菜单系统,可以在除 IE7 之外的所有主浏览器中完美运行,动画效果有效但定位关闭,认为它与数学以及 IE7 如何处理边距/填充等有关。

我已经为 IE7 设置了一个“静态”菜单,我想将它换成 javascript 菜单。

这是我的菜单代码:

<div id="topmenu">
    <jdoc:include type="modules" name="top" />
    <div id="ie-cont">
    <script type="text/javascript" src="/templates/beez5/javascript/script.js">       </script>
    <div id="slide"></div>      
    </div>
  </div>
  <!-- IE7 static menu -->
  <!--[if IE 7]>
<script type='text/javascript'>
$('#ie-cont').remove();
</script>
  <div id="highlight"></div>
    <?php  
switch ($parentmenu) {
case 101 : echo "<script type='text/javascript'>document.getElementById('highlight').className = 'home';</script>";
break;
case 103 : echo "<script type='text/javascript'>document.getElementById('highlight').className = 'about';</script>";
break;
case 106 :
case 165 :
case 166 :
case 167 :
case 168 : 
echo "<script type='text/javascript'>document.getElementById('highlight').className = 'services';</script>";
break;
case 161 : echo "<script type='text/javascript'>document.getElementById('highlight').className = 'test';</script>";
break;
case 104 :
case 102 : 
echo "<script type='text/javascript'>document.getElementById('highlight').className = 'contact';</script>";
}
?>  
<![endif]-->

我可以删除 #slide div 或附加它,但 javascript 文件在寻找 #slide div 时不断出现错误,但甚至将其移动到带有 #slide div 的 div 中并删除它似乎不起作用。关于当访问者在 IE7 中查看时如何卸载 javascript 文件的任何建议(我知道不会有太多关于但合同上我必须支持它的建议!)

我在下面添加了 javascript 代码:

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)}
}};}();
4

2 回答 2

0

如果您的 script.js 引用了#slide,它将出错。您没有显示 script.js 的内容,因此很难说...如果您在 $(document).ready(function(){...}) 或 $(function(){ 中进行了初始化。 ..}) 应该没问题。

于 2012-05-14T23:23:27.543 回答
0

有条件的评论是要走的路。确保您的菜单初始化也落在条件注释的正确一侧。

于 2012-05-15T01:06:56.823 回答