Я не могу понять, что заставляет IE8 игнорировать этих наблюдателей. Работает в FF, Chrome (10) и Safari. Он никогда не достигает точек останова, установленных в IE8 Developer Tools.
<script type="text/javascript">
//<![CDATA[
var timeoutHolder = null;
function displayZoom(id){
window.clearTimeout(timeoutHolder); //if we are coming from another hover target, prevent the opacity reset
if($('mini-main').getOpacity()!=0.4)
new Effect.Opacity('mini-main',{from:1.0,to:0.4,duration:0.5});
new Effect.Appear(id,{duration:0.3});
}
function resetZoom(id){
timeoutHolder = window.setTimeout(function(){
new Effect.Opacity('mini-main',{from:0.4,to:1.0,duration:0.5});
}, 100); //gives us 100 ms for user to move onto another target before we reset the opacity
new Effect.Fade(id,{duration:0.5});
}
$$('.mini-target').each(function(target_div){
target_div.observe('mouseover',function(){
displayZoom(target_div.id+'-hover');
});
target_div.observe('mouseout',function(){
resetZoom(target_div.id+'-hover');
});
});
//]]>
</script>
связанный phtml:
<img src="<?php echo Mage::getBaseUrl('media').'Main.jpg'?>" id="mini-main"/>
<div id="mini-target-1" class="mini-target"></div>
<div id="mini-target-2" class="mini-target"></div>
<div id="mini-target-3" class="mini-target"></div>
<div id="mini-target-4" class="mini-target"></div>
<div id="mini-target-1-hover" class="mini-hover" style="display:none">
<img src="<?php echo Mage::getBaseUrl('media').'mini-rollover-1.png'?>"/>
</div>
<div id="mini-target-2-hover" class="mini-hover" style="display:none">
<img src="<?php echo Mage::getBaseUrl('media').'mini-rollover-2.png'?>"/>
</div>
<div id="mini-target-3-hover" class="mini-hover" style="display:none">
<img src="<?php echo Mage::getBaseUrl('media').'mini-rollover-3.png'?>"/>
</div>
<div id="mini-target-4-hover" class="mini-hover" style="display:none">
<img src="<?php echo Mage::getBaseUrl('media').'mini-rollover-4.png'?>"/>
</div>
Я также пытался прикрепить наблюдателей по отдельности (без each
), но это не имеет значения:
$('mini-target-2').observe('mouseover',function(){
displayZoom('mini-target-2-hover');
});
$('mini-target-2').observe('mouseout',function(){
resetZoom('mini-target-2-hover');
});
Спасибо
JD