Добавить класс animate.css в mouseenter и mouseleave

Я хотел бы использовать animate.css для fadeIn/fadeOut контента, когда пользователь наводит курсор на изображение.

Я пытаюсь выяснить, как лучше всего переключать классы с FadeIn и FadeInUp на mouseenter на FadeOut и FadeOutDown на mouseleave.

Пример Codepen

CSS

.overlay{
position: absolute;
top: 0;
height: 100%;
width: 100%;
background: rgba(40,40,40,0.88);
left: 0;
padding: 10px;
text-align: left;
display: none;
}
.col-sm-6:hover .overlay{
display: block;
}
.overlay h2{
font-size: 20px;
color: #fff;
}
.overlay p{
color: #bbbbbb;
}
.linkbox{
position: absolute;
height: 50px;
bottom: 0;
left: 0;
background: #000;
width: 100%;
padding: 16px;
text-align: left;
color: #fff;
}
.caption{
display: none;
}

Любая помощь / совет / предложения будут оценены!

3 ответа

Решение

Попробуйте этот скрипт:

$('.col-sm-6').on('mouseenter', function(){
  $('.overlay').addClass('fadeIn fadeInUp');
  $('.overlay').removeClass('fadeOut fadeOutDown');
  $('.overlay').css('display', 'block');
});

$('.col-sm-6').on('mouseleave', function(){
  $('.overlay').removeClass('fadeIn fadeInUp');
  $('.overlay').addClass('fadeOut fadeOutDown');
  $('.overlay').css('display', 'block');
  setTimeout(function(){
     $('.overlay').css('display', 'none');
  }, 1000);
});

const box = document.querySelector(".box");

box.addEventListener("mouseenter",function(){
  const move = "shake";
  this.classList.add(move);
  
  this.addEventListener("animationend",function(){
    this.classList.remove(move);
  });
  
  this.addEventListener("mouseleave",function(){
    this.classList.remove(move);
  });
  
});
.box{
  background: skyblue;
  width: 5em;
  height: 5em;
}
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/animate.css/3.5.2/animate.min.css">
<div class="box animated "></div>

Вместо этого используйте jQuery. Оформить заказ на этот Codepen.

Также есть некоторые незначительные изменения CSS, которые также комментируются в коде CSS. Например, не использовать .col-sm-6 напрямую, так как они очень распространенные классы и т. д.

Для справки, ваш JS должен выглядеть так:

$(".screenshot").hover(function () {
    //stuff to do on mouse enter
    var overlay_div = $(this).find('.overlay');
    overlay_div.removeClass('fadeOut');
    overlay_div.addClass('fadeIn');
    overlay_div.find('.another-animation').removeClass('fadeOutDown');
    overlay_div.find('.another-animation').addClass('fadeInUp');
    overlay_div.css('display', 'block');
}, 
function () {
    //stuff to do on mouse leave
    var overlay_div = $(this).find('.overlay');
    $(this).find('.overlay').removeClass('fadeIn');
    $(this).find('.overlay').addClass('fadeOut');
    overlay_div.find('.another-animation').removeClass('fadeInUp');
    overlay_div.find('.another-animation').addClass('fadeOutDown');
    setTimeout(function() {
        overlay_div.css('display', 'none');
    }, 1000);
});

Надеюсь это поможет!

Другие вопросы по тегам