[英]jQuery Cycle plugin IE6/7 issues
我已经使用Cycle插件实现了幻灯片演示,该插件可在除IE6&7之外的所有浏览器中使用,IE6&7的图像仅显示在列表中,并且#page_copy div没有隐藏。 我整天都在浏览代码,没有任何运气,也不完全确定我应该寻找的方式或内容。
调试此问题的最佳方法是什么? 我知道在删除其余代码后,#page_copy div隐藏了,并且我尝试了反向操作(没有结果)
<script type="text/javascript" charset="utf-8">
jQuery.fn.fadeToggle = function(speed, easing, callback) {
return this.animate({opacity: 'toggle'}, speed, easing, callback);
};
$(document).ready(function() {
$('#page_copy').hide();
$('a#info_close_button').click(function() {
$('#page_copy').fadeOut(200);
return false;
});
$('a#info_button').click(function() {
$('#page_copy').fadeToggle(200);
return false;
});
});
$(window).load(function() {
// vertically center single image
var $image_cnt = $("#images > img").size();
if($image_cnt < 2) {
var $single_img = $("#images").children(':first-child');
var h = $single_img.height();
$single_img.css({
marginTop: (620 - h) / 2,
});
$(".next").css("display","none");
$(".prev").css("display","none");
}
});
// wait until images have loaded before starting cycle
$(window).load(function() {
// front image rotator
$('#images').cycle({
fx: 'fade',
speed: 300,
next: '.next',
prev: '.prev',
containerResize: 0,
timeout: 0,
delay: -2000,
before: onBefore
});
});
// hide all but the first image when page loads
$(document).ready(function() {
$('#images img:gt(0)').hide();
});
// callback fired when each slide transition begins
function onBefore(curr,next,opts) {
var $slide = $(next);
var w = $slide.width();
var h = $slide.height();
$slide.css({
marginTop: (620 - h) / 2,
marginLeft: (650 - w) / 2
});
};
</script>
我真的不明白为什么你有多个$(document).ready
和$(window).load
..
也许您应该尝试将所有内容放在单个$(document).ready
块中。
另外,在<script>
标记的开头移动function onBefore(...)
的定义。 直接在jQuery.fn.fadeToggle
代码之前。
尝试在这段代码的结尾处也删除不需要的逗号
$single_img.css({
marginTop: (620 - h) / 2, //<---- remove comma
});
并删除不需要的分号
function onBefore(curr,next,opts) {...}; //<--- unneeded
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.