我正在使用一个灯箱来显示带有照片的评论。问题是,当我向下滚动查看灯箱并滚动回顶部时,即使在指定顶部后,顶部边距也会发生变化。
我要指定顶部和左侧的jQuery代码是:
jQuery.fn.center = function() {
this.css("position","fixed");
var top = "20px";
left = ( $(window).width() - this.width() ) / 2+$(window).scrollLeft()+"px";
this.animate({top: top, left: left});
return this;
}
$('#tp-lightboxactitem').center();
这是灯箱div的HTML:
<div class="dark-lightbox lightboxitem tp-lightboxactitem-loaded" id="tp-lightboxactitem" style="display: block; top: 20px; left: 314.5px; position: fixed; margin-top: 30px;">
<div>
<center>
<img src="uploads/_DSC9322_watcopy_bor_5_$1$uh2.fw5.$uFln.yw5QjSgVKjmhD8.jpg?id=3&pic=113" class="tp-mainimage" id="plzxc">
</center>
</div>
<div class="dark-lightbox infofield">
<div class="dark-lightbox title"></div>
<div class="dark-lightbox pageofformat">( 1 / 5 )</div>
<div class="dark-lightbox description" id="dark-lightbox description">
滚动前的显示方式
[滚动前的显示方式][1]
向下滚动然后再次向上滚动后的显示方式
[向下滚动然后再次向上滚动后的显示情况][2]
通过进行小的更改解决了这个问题
这是代码,希望它能帮助一些需要的人
cssAnimate({'left':($(window).width()/2 - thisw/2)+'px', 'top':'20px' },{duration:300,queue:false});
尝试使用类似的东西。希望它能解决问题。
$("#YourDivID").animate({"marginTop": ($(window).scrollTop() + 30) + "px"}, "slow" );