JQuery вопрос скрытия элемента для нескольких элементов - PullRequest
0 голосов
/ 02 ноября 2019

Пожалуйста, рассмотрите фрагмент ниже.

$(document).ready(function(){
 $(".like-btn").hover(function() {
  var rowid = $(this).attr("data-rowid");
  $(".reaction-box[data-rowid='" + rowid + "']").fadeIn(100, function() {
    $(".reaction-icon").each(function(i, e) {
      setTimeout(function(){
        $(e).addClass("shows");
      }, i * 100);
    });
  });
}, function() {
  var rowid = $(".like-btn").attr("data-rowid");
  setTimeout(function(){
    $(".reaction-box[data-rowid='" + rowid + "']").fadeOut(300, function(){
      $(".reaction-icon").removeClass("shows")
    })
  }, 500);
});
});
.feed .like-btn {
        width: 44px;
        height: 25px;
        background: #D0D0D0;
        position: absolute;
        bottom: 13px;
        left: 13%;
        top: 10%;
        cursor: pointer;
      }
      .feed .like-btn::before {
        content: ".";
        opacity: 0;
        display: block;
        width: 44px;
        height: 10px;
        position: absolute;
        top: -10px;
        left: 0;
      }
      .feed .like-btn .reaction-box {
        position: absolute;
        width: 155px;
        height: 55px;
        background: #FFF;
        box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
        border-radius: 28px;
        left: -25px;
        bottom: 35px;
        display: none;
      }
      .feed .like-btn .reaction-box .reaction-icon.angry {
        animation: fadeInLoad-angry 0.3s;
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out;
        background-position: 0px 0px;
      }
      .feed .like-btn .reaction-box .reaction-icon.flower {
        animation: fadeInLoad-flower 0.3s;
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out;
        background-position: 0px -40px;
      }
      .feed .like-btn .reaction-box .reaction-icon.haha {
        animation: fadeInLoad-haha 0.3s;
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out;
        background-position: 0px -80px;
      }
      .feed .like-btn .reaction-box .reaction-icon.like {
        animation: fadeInLoad-like 0.3s;
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out;
        background-position: 0px -120px;
      }
      .feed .like-btn .reaction-box .reaction-icon.love {
        animation: fadeInLoad-love 0.3s;
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out;
        background-position: 0px -160px;
      }
      .feed .like-btn .reaction-box .reaction-icon.sad {
        animation: fadeInLoad-sad 0.3s;
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out;
        background-position: 0px -200px;
      }
      .feed .like-btn .reaction-box .reaction-icon.wow {
        animation: fadeInLoad-wow 0.3s;
        -webkit-animation-timing-function: ease-out;
        animation-timing-function: ease-out;
        background-position: 0px -240px;
      }
      .feed .like-btn .reaction-box .reaction-icon {
        display: inline-block;
        width: 40px;
        height: 40px;
        background: url();
        background-size: cover;
        border-radius: 20px;
        margin: 8px -1px 0 8px;
        text-align: center;
        pointer-events: none;
        transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
        opacity: 0;
        transform: translate(0, 100px) scale(0);
      }
      .feed .like-btn .reaction-box .reaction-icon label {
        padding: 3px 5px 3px 5px;
        position: relative;
        top: -24px;
        border-radius: 10px;
        font-size: 11px;
        color: #FFF;
        background: #333;
        visibility: hidden;
      }
      .feed .like-btn .reaction-box .reaction-icon.shows {
        opacity: 1;
        transform: translate(0, 0) scale(1);
        pointer-events: auto;
      }
      .feed .like-btn .reaction-box .reaction-icon:hover {
        transform: scale(1.4);
        transform-origin: bottom;
      }
      .feed .like-btn .reaction-box .reaction-icon:hover label {
        visibility: visible;
      }
      .feed .like-btn:hover {
        background: #718C00;
      }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<div class="feed">
  <a class="like-btn" data-rowid="1"> Hover
    <div class="reaction-box" data-rowid="1">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 50px" data-rowid="2"> Hover
    <div class="reaction-box" data-rowid="2">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 100px" data-rowid="3"> Hover
    <div class="reaction-box" data-rowid="3">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 150px" data-rowid="4"> Hover
    <div class="reaction-box" data-rowid="4">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  </div>

Как видите, у этого фрагмента есть несколько проблем. Когда вы наводите курсор на одну кнопку, вы видите, что реакции всплывают, но затем они не исчезают и не прячутся, когда курсор отводится от кнопки. Когда вы наводите 2-3 из них сразу, и все реакции отображаются повторно, наведите еще одну кнопку, и анимация воспроизводится и для других блоков реакции. Все должно быть просто. Наведите на одну кнопку, и реакция всплывает на это, парить, и он прячется. Вот и все. Так же, как Facebook. Кроме того, на мобильных устройствах он отображается при нажатии, но как сделать так, чтобы он отображался при нажатии кнопки (например, в Facebook).

Ответы [ 4 ]

0 голосов
/ 03 ноября 2019

Может быть лучше использовать this в вашем селекторе, чтобы сделать его менее сложным. Например, $(".reaction-box", this) выберет элемент с этим классом в пределах this. Точно так же вы можете сделать $(this).find(".reaction-box"), и он будет иметь тот же эффект.

Рабочий пример:

$(function() {
  $(".like-btn").hover(function(e) {
    $(".reaction-box", this).fadeIn(100, function() {
      $(".reaction-icon", this).each(function(i, e) {
        setTimeout(function() {
          $(e).addClass("shows");
        }, i * 100);
      });
    });
  }, function(e) {
    $(".reaction-box", this).fadeOut(800, function() {
      $(".reaction-icon", this).removeClass("shows")
    });
  });
});
.feed .like-btn {
  width: 44px;
  height: 25px;
  background: #D0D0D0;
  position: absolute;
  bottom: 13px;
  left: 13%;
  top: 10%;
  cursor: pointer;
}

.feed .like-btn::before {
  content: ".";
  opacity: 0;
  display: block;
  width: 44px;
  height: 10px;
  position: absolute;
  top: -10px;
  left: 0;
}

.feed .like-btn .reaction-box {
  position: absolute;
  width: 155px;
  height: 55px;
  background: #FFF;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
  border-radius: 28px;
  left: -25px;
  bottom: 35px;
  display: none;
}

.feed .like-btn .reaction-box .reaction-icon.angry {
  animation: fadeInLoad-angry 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px 0px;
}

.feed .like-btn .reaction-box .reaction-icon.flower {
  animation: fadeInLoad-flower 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -40px;
}

.feed .like-btn .reaction-box .reaction-icon.haha {
  animation: fadeInLoad-haha 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -80px;
}

.feed .like-btn .reaction-box .reaction-icon.like {
  animation: fadeInLoad-like 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -120px;
}

.feed .like-btn .reaction-box .reaction-icon.love {
  animation: fadeInLoad-love 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -160px;
}

.feed .like-btn .reaction-box .reaction-icon.sad {
  animation: fadeInLoad-sad 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -200px;
}

.feed .like-btn .reaction-box .reaction-icon.wow {
  animation: fadeInLoad-wow 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -240px;
}

.feed .like-btn .reaction-box .reaction-icon {
  display: inline-block;
  width: 40px;
  height: 40px;
  background: url();
  background-size: cover;
  border-radius: 20px;
  margin: 8px -1px 0 8px;
  text-align: center;
  pointer-events: none;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  opacity: 0;
  transform: translate(0, 100px) scale(0);
}

.feed .like-btn .reaction-box .reaction-icon label {
  padding: 3px 5px 3px 5px;
  position: relative;
  top: -24px;
  border-radius: 10px;
  font-size: 11px;
  color: #FFF;
  background: #333;
  visibility: hidden;
}

.feed .like-btn .reaction-box .reaction-icon.shows {
  opacity: 1;
  transform: translate(0, 0) scale(1);
  pointer-events: auto;
}

.feed .like-btn .reaction-box .reaction-icon:hover {
  transform: scale(1.4);
  transform-origin: bottom;
}

.feed .like-btn .reaction-box .reaction-icon:hover label {
  visibility: visible;
}

.feed .like-btn:hover {
  background: #718C00;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<div class="feed">
  <a class="like-btn" data-rowid="1"> Hover
    <div class="reaction-box" data-rowid="1">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 50px" data-rowid="2"> Hover
    <div class="reaction-box" data-rowid="2">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 100px" data-rowid="3"> Hover
    <div class="reaction-box" data-rowid="3">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 150px" data-rowid="4"> Hover
    <div class="reaction-box" data-rowid="4">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
</div>
0 голосов
/ 02 ноября 2019

Решение только для CSS, своего рода: использование :hover для его отображения. Очевидно, что требуется гораздо больше работы, но комбинация переходов должна сделать это

.feed .like-btn {
  width: 44px;
  height: 25px;
  background: #D0D0D0;
  position: absolute;
  bottom: 13px;
  left: 13%;
  top: 10%;
  cursor: pointer;
}

.feed .like-btn::before {
  content: ".";
  opacity: 0;
  display: block;
  width: 44px;
  height: 10px;
  position: absolute;
  top: -10px;
  left: 0;
}

.feed .like-btn .reaction-box {
  position: absolute;
  width: 155px;
  height: 55px;
  background: #FFF;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
  border-radius: 28px;
  left: -25px;
  bottom: 35px;
  display: none;
}

.feed .like-btn .reaction-box .reaction-icon.angry {
  animation: fadeInLoad-angry 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px 0px;
}

.feed .like-btn .reaction-box .reaction-icon.flower {
  animation: fadeInLoad-flower 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -40px;
}

.feed .like-btn .reaction-box .reaction-icon.haha {
  animation: fadeInLoad-haha 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -80px;
}

.feed .like-btn .reaction-box .reaction-icon.like {
  animation: fadeInLoad-like 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -120px;
}

.feed .like-btn .reaction-box .reaction-icon.love {
  animation: fadeInLoad-love 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -160px;
}

.feed .like-btn .reaction-box .reaction-icon.sad {
  animation: fadeInLoad-sad 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -200px;
}

.feed .like-btn .reaction-box .reaction-icon.wow {
  animation: fadeInLoad-wow 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -240px;
}

.feed .like-btn .reaction-box .reaction-icon {
  display: inline-block;
  width: 40px;
  height: 40px;
  background: url();
  background-size: cover;
  border-radius: 20px;
  margin: 8px -1px 0 8px;
  text-align: center;
  pointer-events: none;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  opacity: 0;
  transform: translate(0, 100px) scale(0);
}

.feed .like-btn .reaction-box .reaction-icon label {
  padding: 3px 5px 3px 5px;
  position: relative;
  top: -24px;
  border-radius: 10px;
  font-size: 11px;
  color: #FFF;
  background: #333;
  visibility: hidden;
}

.feed .like-btn .reaction-box .reaction-icon.shows {
  opacity: 1;
  transform: translate(0, 0) scale(1);
  pointer-events: auto;
}

.feed .like-btn .reaction-box .reaction-icon:hover {
  transform: scale(1.4);
  transform-origin: bottom;
}

.feed .like-btn .reaction-box .reaction-icon:hover label {
  visibility: visible;
}

.feed .like-btn:hover {
  background: #718C00;
}

.like-btn:hover .reaction-box{
  display: block;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<div class="feed">
  <a class="like-btn" data-rowid="1"> Hover
    <div class="reaction-box" data-rowid="1">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 50px" data-rowid="2"> Hover
    <div class="reaction-box" data-rowid="2">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 100px" data-rowid="3"> Hover
    <div class="reaction-box" data-rowid="3">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 150px" data-rowid="4"> Hover
    <div class="reaction-box" data-rowid="4">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
</div>
0 голосов
/ 02 ноября 2019

Может быть, вы можете попробовать обновить свой jquery, используя этот скрипт:

$(document).ready(function(){
 $(".like-btn").each(function(){
    $(this).on({
    'mouseenter': function(e) {
        e.preventDefault();
        $(this).find(".reaction-box").fadeIn(100, function(){

             $(this).find(".reaction-icon").each(function(i, e) {
            setTimeout(function(){
              $(e).addClass("shows");
            }, i * 100);
          });


            }
            )
 },
      'mouseleave': function(e){
            e.preventDefault();
          var el;
            $(this).find(".reaction-icon").each(function(i, e) {
            if(i == 0){
                el = $(this).closest('.reaction-box').attr('data-rowid');
            }
            setTimeout(function(){
              $(e).removeClass("shows");
            }, i * 100);
          });

           setTimeout(function(){
            $('.reaction-box[data-rowid="' + el + '"]').fadeOut(50);
          }, 400);
         }
});
});
});

как эта скрипка jsfiddle

0 голосов
/ 02 ноября 2019

rowid для fadeout с использованием var rowid = $(".like-btn").attr("data-rowid"); всегда будет возвращать 1, поскольку вы явно ссылаетесь на .like-btn. Вместо этого вам нужно изменить как var rowid = $(this).attr("data-rowid");, что приведет к извлечению идентификатора строки.

$(document).ready(function() {
  $(".like-btn").hover(function() {
    var rowid = $(this).attr("data-rowid");
    $(".reaction-box[data-rowid='" + rowid + "']").fadeIn(100, function() {
      $(".reaction-icon").each(function(i, e) {
        setTimeout(function() {
          $(e).addClass("shows");
        }, i * 100);
      });
    });
  }, function() {
    var rowid = $(this).attr("data-rowid");
    setTimeout(function() {
      $(".reaction-box[data-rowid='" + rowid + "']").fadeOut(300, function() {
        $(".reaction-icon").removeClass("shows")
      })
    }, 500);
  });
});
.feed .like-btn {
  width: 44px;
  height: 25px;
  background: #D0D0D0;
  position: absolute;
  bottom: 13px;
  left: 13%;
  top: 10%;
  cursor: pointer;
}

.feed .like-btn::before {
  content: ".";
  opacity: 0;
  display: block;
  width: 44px;
  height: 10px;
  position: absolute;
  top: -10px;
  left: 0;
}

.feed .like-btn .reaction-box {
  position: absolute;
  width: 155px;
  height: 55px;
  background: #FFF;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
  border-radius: 28px;
  left: -25px;
  bottom: 35px;
  display: none;
}

.feed .like-btn .reaction-box .reaction-icon.angry {
  animation: fadeInLoad-angry 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px 0px;
}

.feed .like-btn .reaction-box .reaction-icon.flower {
  animation: fadeInLoad-flower 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -40px;
}

.feed .like-btn .reaction-box .reaction-icon.haha {
  animation: fadeInLoad-haha 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -80px;
}

.feed .like-btn .reaction-box .reaction-icon.like {
  animation: fadeInLoad-like 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -120px;
}

.feed .like-btn .reaction-box .reaction-icon.love {
  animation: fadeInLoad-love 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -160px;
}

.feed .like-btn .reaction-box .reaction-icon.sad {
  animation: fadeInLoad-sad 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -200px;
}

.feed .like-btn .reaction-box .reaction-icon.wow {
  animation: fadeInLoad-wow 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-position: 0px -240px;
}

.feed .like-btn .reaction-box .reaction-icon {
  display: inline-block;
  width: 40px;
  height: 40px;
  background: url();
  background-size: cover;
  border-radius: 20px;
  margin: 8px -1px 0 8px;
  text-align: center;
  pointer-events: none;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  opacity: 0;
  transform: translate(0, 100px) scale(0);
}

.feed .like-btn .reaction-box .reaction-icon label {
  padding: 3px 5px 3px 5px;
  position: relative;
  top: -24px;
  border-radius: 10px;
  font-size: 11px;
  color: #FFF;
  background: #333;
  visibility: hidden;
}

.feed .like-btn .reaction-box .reaction-icon.shows {
  opacity: 1;
  transform: translate(0, 0) scale(1);
  pointer-events: auto;
}

.feed .like-btn .reaction-box .reaction-icon:hover {
  transform: scale(1.4);
  transform-origin: bottom;
}

.feed .like-btn .reaction-box .reaction-icon:hover label {
  visibility: visible;
}

.feed .like-btn:hover {
  background: #718C00;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<div class="feed">
  <a class="like-btn" data-rowid="1"> Hover
    <div class="reaction-box" data-rowid="1">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 50px" data-rowid="2"> Hover
    <div class="reaction-box" data-rowid="2">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 100px" data-rowid="3"> Hover
    <div class="reaction-box" data-rowid="3">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
  <a class="like-btn" style="margin-top: 150px" data-rowid="4"> Hover
    <div class="reaction-box" data-rowid="4">
      <div class="reaction-icon like">
        <label>Like</label>
      </div>
      <div class="reaction-icon love">
        <label>Love</label>
      </div>
      <div class="reaction-icon haha">
        <label>Haha</label>
      </div>
    </div>
  </a>
</div>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...