灯箱顶部边距在向下滚动一次后又向上滚动一次



我正在使用一个灯箱来显示带有照片的评论。问题是,当我向下滚动查看灯箱并滚动回顶部时,即使在指定顶部后,顶部边距也会发生变化。

我要指定顶部和左侧的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&amp‌​;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" );

最新更新