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