-1
我一直坚持这一段时间了。我正在尝试制作自己的Scrollspy。事情是,它只能硬编码的时候,如果我尝试做它通过变量它不断给我自定义滚动jquery只适用于手动编码
$(document).ready(function() {
setInterval(check, 100);
});
function isScrolledIntoView()
{
var docViewTop = $(window).scrollTop();
var docViewBottom = docViewTop + $(window).height();
var year = $('.year').eq(2).attr("class");
var test = year.split(' ');
test = test[1];
var elemTop = $(".item."+test).offset().top;
var elemBottom = elemTop + $(".item."+test).height();
return ((elemBottom <= docViewBottom) && (elemTop >= docViewTop));
}
var check = function(){
var itemslength = $('.year').length;
for (var i = itemslength-1; i >= 0; i--) {
var year = $('.year').eq(i).attr("class");
var yearsplitted = year.split(' ');
if(isScrolledIntoView())
{
$(".year.2016").addClass("item-active");
}
else
{
$(".year.2016").removeClass("item-active");
}
}
};
您可以在第一功能
var elemTop = $(".item."+test).offset().top;
看到如果我试图做到这一点通过变量,它不起作用。
编辑:我使用了错误的循环。
不太能工作,这就是我想要做的:[http://jsfiddle.net/DFh7z/70/](http://jsfiddle.net/DFh7z/70/)我不断收到'Uncaught TypeError:无法读取未定义的属性'top' –