所以我要做的是我有3 div
每个div
应该滚动到另一个div
,当它到达顶部时,它的位置应该是固定的。
所以一切正常,直到我们调整窗口大小(它需要刷新页面)。 如何解决这个问题?我的意思是,如果不刷新页面,我们不能这样做吗?
我使用了调整大小,但它不适合我。而且我不确定这是否是使用调整大小的正确方法
我工作的JSFiddle副本
var $cache = $('#two');
var $cache2=$('#three');
var vTop = $cache.offset().top - parseFloat($cache.css('margin-top').replace(/auto/, 0));
var vTop2 = $cache2.offset().top - parseFloat($cache2.css('margin-top').replace(/auto/, 0));
$(window).scroll(function (event) {
var vTop = $cache.offset().top - parseFloat($cache.css('margin-top').replace(/auto/, 0));
var vTop2 = $cache2.offset().top - parseFloat($cache2.css('margin-top').replace(/auto/, 0));
});
$(window).scroll(function (event) {
var y = $(this).scrollTop();
if (y >= vTop) {
$cache.addClass('stuck');
$('#one').addClass('stuck');
$('#two h2').addClass('stuck');
} else if(y>=vTop2)
{
$('#two h2').removeClass('stuck');
}
else {
$cache.removeClass('stuck');
$('#one').removeClass('stuck');
$('#two h2').removeClass('stuck');
}
});
答案 0 :(得分:0)
使用window.onresize
处理元素:
window.onresize = function(event) {
//handling code in between
}