jQuery在一个水平可滚动div中循环:IE问题

时间:2009-06-23 14:07:21

标签: jquery

我在IE 6和7中遇到问题,循环幻灯片嵌入在水平可滚动div中。我已经使用这种技术(http://www.switchonthecode.com/tutorials/using-jquery-slider-to-scroll-a-div)来创建水平可滚动div。我会在可滚动的div中嵌入Cycle幻灯片。所有这些都在FF3,Opera,Chrome中正常工作。在IE 6和7中,图像的容器和导航缩略图是固定的,它们不会滚动。可滚动div中的每个其他div或元素都可以正常工作。

这是我的代码:

<div id="content">
  <div id="contentscroll">
    <div id="contentholder">

      <div class="contentitem">
        <span class="name">ABC</span>
        <span class="price">25 €</span>
    <div class="photo">
          <img src="642_03_prod[1].png" height="280" width="280" />
          <img src="855_02_prod[1].png" height="280" width="280" />
          <img src="856_01_prod[1].png" height="280" width="280" />
        </div>
        <ul class="colors">
          <li><a href="#"><img src="642_03_prod[1].png" height="25" width="25" /></a></li>
          <li><a href="#"><img src="855_02_prod[1].png" height="25" width="25" /></a></li>
          <li><a href="#"><img src="856_01_prod[1].png" height="25" width="25" /></a></li>
        </ul>
      </div>

      <!--- other contentitem --->

    </div> <!--- end contentholder --->
  </div> <!--- end contentscroll --->
</div> <!--- end content --->

这是CSS:

#contentscroll {
    background: transparent;
    width: 990px;
    height: 386px;
    overflow: hidden;
}

#contentholder {
  width: 1500px;
  height: 386px;
}

.contentitem {
  width: 330px;
  height: 100%;
  padding: 0;
  float: left;
}

.contentitem .name, .contentitem .price {
  width: 330px;
  height: 18px;
  margin:0;
  padding: 0;
  float: left;
  text-align:center;
  font:12px Arial, Helvetica, sans-serif;
  color: #FFF;
}

.photo{
    height: 280px;
}

ul.colors { margin:0; padding:0; height: 18px;}
ul.colors { list-style-type: none; display: inline; margin:0; padding:0; }
ul.colors li { background: none; display: inline; margin: 0; padding: 0; }
ul.colors li a { background: none; border: 0; margin: 0; margin-right: 2px; padding:0; color: #FFF;}
ul.colors li a img { background: none; border: 0; margin: 0; padding:0; }

这是JS:

$('.photo').cycle({ 
    fx:     'turnDown', 
    speed:  'fast', 
    timeout: 0, 
    pager:  '.colors',
    fastOnEvent: true,
    slideExpr:     null,
    cleartype:  true,
    cleartypeNoBg:  true,
    pagerAnchorBuilder: function(idx, slide) { 
        // return selector string for existing anchor 
        return '.colors li:eq(' + idx + ') a'; 
} 
});

任何人都可以帮助我吗? Cycle是否将CSS专有权应用于.photo和.colors这个事实会产生这个问题吗? .name span e .price span scroll。

2 个答案:

答案 0 :(得分:0)

我用DebugBar控制:循环添加一些样式和属性:

<DIV class=photo style="WIDTH: 280px; POSITION: relative; HEIGHT: 280px" cycleStop="0" cyclePause="0" cycleTimeout="0" jQuery1245766927421="13">

<IMG style="DISPLAY: none; Z-INDEX: 3; LEFT: 0px; ZOOM: 1; POSITION: absolute; TOP: 280px; HEIGHT: 0px" height=280 src="642_03_prod[1].png" width=280 cycleH="280" cycleW="280" jQuery1245766927421="10">
<IMG style="DISPLAY: block; Z-INDEX: 4; LEFT: 0px; WIDTH: 280px; ZOOM: 1; POSITION: absolute; TOP: 0px; HEIGHT: 280px" height=280 src="855_02_prod[1].png" width=280 cycleH="280" cycleW="280" jQuery1245766927421="11">
<IMG style="DISPLAY: none; Z-INDEX: 1; LEFT: 0px; POSITION: absolute; TOP: 0px; HEIGHT: 0px" height=280 src="856_01_prod[1].png" width=280 cycleH="280" cycleW="280" jQuery1245766927421="12">

</DIV>

图像div容器上有position:relative,imgs上有position: absolute, display: block。 我认为这些属性是造成这个问题的原因,但我不知道如何删除它们。

答案 1 :(得分:0)

文件jquery.cycle.all.js:

第187行:

// container requires non-static position so that slides can be position within
    if ($cont.css('position') == 'static')
        $cont.css('position', 'relative');

第212行:

// set position and zIndex on all the slides
    $slides.css({position: 'absolute', top:0, left:0}).hide().each(function(i) {
        var z = first ? i >= first ? els.length - (i-first) : first-i : els.length-i;
        $(this).css('z-index', z)
    });

我认为JS的这两部分对于解决问题非常重要,但我不知道如何。