0

I am trying to add class when image will display. JSFIDDLE

Here I have two image. I am trying to add class when any image will be on screen. Now only adding on first image. I tried to check through closest() but not getting any value

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>
Lemon Kazi
  • 3,148
  • 2
  • 31
  • 53

2 Answers2

0

You can use 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/

Ihsan S
  • 54
  • 6
  • Thanks for your answer. I tried to add class on image. then it's shaking. can u please check it. http://jsfiddle.net/6p2hwe8x/3/ – Lemon Kazi Nov 12 '18 at 15:03
0

Function to check for element is present in the viewport or not. elementInViewport has been taken from this SO_Answer. Have a look for more understanding.

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 demo that console.log element state if present in the viewport.

front_end_dev
  • 1,687
  • 1
  • 7
  • 12
  • Thanks for your answer . here you placed id. It's ok Here problem is how can I get those id if my html is different in different place. like some place 2 images. some 3 image. Somehow I can add id by 1/2/3 but I need to get them one by one when scroll – Lemon Kazi Nov 12 '18 at 15:12
  • Itried like this. but it's adding and removing class so it's shaking. can you please check http://jsfiddle.net/zvy4508q/1/ – Lemon Kazi Nov 12 '18 at 15:24
  • 1
    Instead of ids you can maintain list of elements by each page which you need to track calculate accordingly. – front_end_dev Nov 12 '18 at 15:25
  • You can use `debounce` so your scroll function is not call frequently. I have updated your fiddle - http://jsfiddle.net/zvy4508q/2/ . Read more about debounce - https://davidwalsh.name/javascript-debounce-function – front_end_dev Nov 12 '18 at 15:30