Jquery Waypoints刷新

前端之家收集整理的这篇文章主要介绍了Jquery Waypoints刷新前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用路标创建一个粘性div的页面,该div向下滚动页面的位置:固定直到它到达其父div的底部.代码即时使用按预期工作,直到$.waypoints(‘refresh’)被调用,然后粘性div跳回到页面顶部并失去其固定位置.

继承人代码

$('#content').waypoint(function(event,direction){
if (direction === 'down') {
    $(this).removeClass('sticky').addClass('bottomed');
}
else {
    $(this).removeClass('bottomed').addClass('sticky');
}
},{
    offset: function() {
    return $('#leftCol').outerHeight() - $('#content').outerHeight();
}

}).find('#leftCol').waypoint(function(event,direction) {
    $(this).parent().toggleClass('sticky',direction === "down");
    event.stopPropagation();
         });

其中#leftCol是向下滚动页面的div,而#content是其父div.

我有的CSS是:

#content {
width: 975px;
height: auto;
position: relative;
margin-top: 10px;
margin-bottom: 20px;
min-height: 800px;
}

#leftCol {
position: absolute;
width: 974px;
}

.sticky #leftCol {
position:fixed !important;
top:0 !important;
left: 50% !important;
width: 974px !important;
margin-left: -488px;
}

.bottomed #leftCol {
position: absolute !important;
bottom: 0px;
}

关于如何在调用$.waypoints(‘refresh’)时保持#leftCol位置的任何想法都将非常感激.

谢谢

解决方法

不要,不要,不要使用固定位置元素作为航点.请参阅GitHub上的所有以下已结束问题: #64,#44,#32,#26,#24,#13,#10,#4.

这很容易成为关于Waypoints的最容易被误解的事情,并且绝对不能告知Waypoints如何运作得很好.我打算在插件的下一次迭代中更加清楚.

对于任何想知道的人:Waypoints通过查看元素的页面偏移量来工作.但是,当用户滚动时,固定位置元素的页面偏移量会不断变化.因此,每当调用刷新时,无论是手动,通过添加另一个航点,还是通过调整浏览器的大小,该航点的位置都会发生变化,以匹配用户当时在页面滚动中所处的位置.你想要的是一个普通的静态位置元素,它不会使文档流成为航点.在Waypoints项目网站上给出的示例中,航点是一个保留在原位的包装元素,而导航包裹增益并通过CSS丢失固定位置.对于那些不了解页面偏移和CSS的人来说,这很容易做OP在这里所做的事情,因为它看起来很直观.同样,这将在未来的文档/示例中更直接地解决.

原文链接:https://www.f2er.com/jquery/180923.html

猜你在找的jQuery相关文章