на окна прокрутки добавить класс на ближайший селектор - PullRequest
0 голосов
/ 12 ноября 2018

Я пытаюсь добавить класс, когда изображение будет отображаться. 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>

Ответы [ 2 ]

0 голосов
/ 12 ноября 2018

Функция для проверки наличия или отсутствия элемента в окне просмотра.elementInViewport было взято из этого SO_Answer .Ищите больше понимания.

function elementInViewport(el) {
  var top = el.offsetTop;
  var left = el.offsetLeft;
  var width = el.offsetWidth;
  var height = el.offsetHeight;

  while(el.offsetParent) {
    el = el.offsetParent;
    top += el.offsetTop;
    left += el.offsetLeft;
  }

  return (
    top < (window.pageYOffset + window.innerHeight) &&
    left < (window.pageXOffset + window.innerWidth) &&
    (top + height) > window.pageYOffset &&
    (left + width) > window.pageXOffset
  );
}

jsFiddle демонстрация того, что console.log состояние элемента, если оно присутствует в окне просмотра.

0 голосов
/ 12 ноября 2018

Вы можете использовать ScrollMonitor

var el = $(".box");
var watcher = scrollMonitor.create( el );

    watcher.enterViewport(function() {
        console.log( 'I have entered the viewport' );
        el.addClass('animated flip').css('background', 'red');
    });

    watcher.exitViewport(function() {
     console.log( 'I have left the viewport' );
     el.removeClass('animated flip').css('background', 'none');
    });

http://jsfiddle.net/6p2hwe8x/2/

...