Я пытаюсь добавить класс, когда изображение будет отображаться. JSFIDDLE
Здесь у меня два изображения.Я пытаюсь добавить класс, когда любое изображение будет на экране.Теперь добавляем только первое изображение.Я пытался проверить через closest (), но не получил никакого значения
function isScrolledIntoView(elem) {
var docViewTop = $(window).scrollTop();
var docViewBottom = docViewTop + $(window).height();
var elemTop = $(elem).offset().top;
return ((elemTop <= docViewBottom) && (elemTop >= docViewTop));
}
$(window).scroll(function(){
if (isScrolledIntoView('.box')) {
console.log($(this).find('img').html());
$('img').addClass('animated flip').css('background', 'red');
//added background red so you can see it has triggered
}
else {
$('img').removeClass('animated flip');
}
});
.col-md-12 {
height: 1500px;
padding-top: 1000px;
}
.box{
position:relative;
}
.animated {
opacity: 1;
visibility: visible;
transition: opacity 1s 0s, visibility 1s 0s;
z-index: 2;
position: fixed;
top: 0;
left: 0;
}
.rad-slideshow-item {
/* position: relative; */
}
.rad-slideshow-item .rad-asset-wrapper {
display: block;
padding: 0;
position: absolute;
top: 0;
left: 0;
overflow: hidden;
z-index: 3;
}
.animated .rad-slideshow-item.active-adjacent div.rad-asset-wrapper {
background: #000;
opacity: 0;
visibility: hidden;
position: fixed;
top: 0;
left: 0;
transition: opacity 0s 0s, visibility 0s 0s;
z-index: 1;
display: none;
}
.animated .rad-slideshow-item.active-adjacent div.rad-asset-wrapper {
display: block;
transform: translate3d(0, 0, 0);
transition: opacity 0s 1s, visibility 0s 1s;
}
.rad-spinner {
position: absolute;
top: 50%;
left: 50%;
z-index: 2;
transform: translate3d(-50%, -50%, 0);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
<div class="col-md-12 ">
<div class="box">
<img src="https://dummyimage.com/800x800" class="icon"/>
<div class="rad-slideshow-item active-adjacent">
<div class="rad-asset-wrapper">
<h1>WEB<br/>DESIGN</h1>
</div>
</div>
</div>
<div class="box">
<img src="https://dummyimage.com/800x800" class="icon"/>
<div class="rad-slideshow-item active-adjacent">
<div class="rad-asset-wrapper">
<h1>WEB<br/>DESIGN</h1>
</div>
</div>
</div>
</div>