我正在尝试将“活动”类设置为页面上最可见的元素。使用此代码,我可以将页面上显示的元素设置为“活动”类。
我正在为我的无限滚动项目这样做。如果我可以为目标元素提供活动类,则可以更改社交媒体共享过程的页面URL和标题。
git checkout other-nice-branch
$.fn.isInViewport = function() {
var elementTop = $(this).offset().top;
var elementBottom = elementTop + $(this).outerHeight();
var viewportTop = $(window).scrollTop();
var viewportBottom = viewportTop + $(window).height();
return elementBottom > viewportTop && elementTop < viewportBottom;
};
$(window).on('resize scroll', function() {
$('article').each(function() {
if ($(this).isInViewport()) {
$(this).addClass('active');
} else {
$(this).removeClass('active');
}
});
});
答案 0 :(得分:1)
不确定什么是最可见的,但是您可以使用一个标志来指示是否找到了可见元素,将所有元素重置并将活动类设置为找到的第一个。
$.fn.isInViewport = function() {
var elementTop = $(this).offset().top;
var elementBottom = elementTop + $(this).outerHeight();
var viewportTop = $(window).scrollTop();
var viewportBottom = viewportTop + $(window).height();
return elementBottom > viewportTop && elementTop < viewportBottom && elementTop > viewportTop;
};
$(window).on('load resize scroll', function() {
var activeFound = false;
$('article').each(function() {
if (!activeFound) {
if ($(this).isInViewport()) {
$("article.active").removeClass("active");
$(this).addClass('active');
activeFound = true;
}
}
});
});
.active {
color: blue;
}
<article>
<h1>Title 1</h1>
<p>Text... .. .
</p>
</article>
<article>
<h1>Title 2</h1>
<p>Text2... .. .
</p>
</article>
<article>
<h1>Title 2</h1>
<p>Text2... .. .
</p>
</article>
<article>
<h1>Title 1</h1>
<p>Text... .. .
</p>
</article>
<article>
<h1>Title 2</h1>
<p>Text2... .. .
</p>
</article>
<article>
<h1>Title 2</h1>
<p>Text2... .. .
</p>
</article>
<article>
<h1>Title 1</h1>
<p>Text... .. .
</p>
</article>
<article>
<h1>Title 2</h1>
<p>Text2... .. .
</p>
</article>
<article>
<h1>Title 2</h1>
<p>Text2... .. .
</p>
</article>
<article>
<h1>Title 1</h1>
<p>Text... .. .
</p>
</article>
<article>
<h1>Title 2</h1>
<p>Text2... .. .
</p>
</article>
<article>
<h1>Title 2</h1>
<p>Text2... .. .
</p>
</article>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>