Jquery如果滚动是一定数量的像素

是否有内置的jQuery函数来确定滚动的长度?

我正在尝试编写一个函数,如果用户从顶部滚动了50个像素,它将为div添加一个类。

所以代码看起来像这样:

if(userHasScrolled) { $('#myDiv').addClass('hasScrolled'); } 

您可以在滚动处理程序中检查$(document).scrollTop()

 var $document = $(document), $element = $('#some-element'), className = 'hasScrolled'; $document.scroll(function() { if ($document.scrollTop() >= 50) { // user scrolled 50 pixels or more; // do stuff $element.addClass(className); } else { $element.removeClass(className); } }); 

如果您想要添加类名称(无需其他操作),则可以缩短为:

 var $document = $(document), $element = $('#some-element'), className = 'hasScrolled'; $document.scroll(function() { $element.toggleClass(className, $document.scrollTop() >= 50); }); 

请参见http://api.jquery.com/scrollTop/ 。

请注意,使用scroll事件处理程序效率非常低。