我在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。
答案 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的这两部分对于解决问题非常重要,但我不知道如何。