Выполнение эффекта, когда пользователь каждый раз нажимает на элемент - PullRequest
0 голосов
/ 02 мая 2019

Как я могу выполнить этот эффект каждый раз, когда пользователь нажимает на элемент с помощью jquery?

Я добавляю класс пульсации при щелчке, но когда я нажимаю на элемент во второй раз, он не может выполнить, потому чтокласс уже добавлен, как я могу исправить эту проблему?

<div class="circle-ripple"></div>
html, body {
  width: 100%;
  height: 100%;
}

body {
  background-color: #4e4e4e;
  display: flex;
  align-items: center;
  justify-content: center;

}

.circle-ripple {
  background-color: #35ffc3;
  width: 1em;
  height: 1em;
  border-radius: 50%;
}
.ripple {
    -webkit-animation: ripple 0.7s linear;
          animation: ripple 0.7s linear;
  animation-duration:0.5s;

}
@-webkit-keyframes ripple {
  0% {
    box-shadow: 0 0 0 0 rgba(101, 255, 120, 0.3), 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3);
  }
  100% {
    box-shadow: 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3), 0 0 0 8em rgba(101, 255, 120, 0);
  }
}

@keyframes ripple {
  0% {
    box-shadow: 0 0 0 0 rgba(101, 255, 120, 0.3), 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3);
  }
  100% {
    box-shadow: 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3), 0 0 0 8em rgba(101, 255, 120, 0);
  }
}
$(document).ready(function(){
  $(".circle-ripple").click(function(){
    $(this).addClass("ripple");
  });
});

Ответы [ 3 ]

1 голос
/ 02 мая 2019

setTimeout будет лучшим вариантом, я думаю,

$(document).ready(function(){
  $(".circle-ripple").click(function(){
    var data = $(this)
    data.addClass("ripple");
     setTimeout(function() {
        data.removeClass('ripple');
    }, 500)
    
  });
});
html, body {
  width: 100%;
  height: 100%;
}

body {
  background-color: #4e4e4e;
  display: flex;
  align-items: center;
  justify-content: center;

}

.circle-ripple {
  background-color: #35ffc3;
  width: 1em;
  height: 1em;
  border-radius: 50%;
}
.ripple {
    -webkit-animation: ripple 0.7s linear;
          animation: ripple 0.7s linear;
  animation-duration:0.5s;

}
@-webkit-keyframes ripple {
  0% {
    box-shadow: 0 0 0 0 rgba(101, 255, 120, 0.3), 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3);
  }
  100% {
    box-shadow: 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3), 0 0 0 8em rgba(101, 255, 120, 0);
  }
}

@keyframes ripple {
  0% {
    box-shadow: 0 0 0 0 rgba(101, 255, 120, 0.3), 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3);
  }
  100% {
    box-shadow: 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3), 0 0 0 8em rgba(101, 255, 120, 0);
  }
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.0/jquery.min.js"></script>
<div class="circle-ripple"></div>
1 голос
/ 02 мая 2019

Если вы хотите избежать тайм-аутов, вы можете вместо этого переустановить элемент следующим образом (я только изменил JavaScript):

$(document).ready(function(){
  $(".circle-ripple").click(function(){
      // reinsert div with ripple class
      const new_element = $(this).clone(true);
      new_element.addClass("ripple");
      $(this).before(new_element);
      $(this).remove();
  });
});
html, body {
  width: 100%;
  height: 100%;
}

body {
  background-color: #4e4e4e;
  display: flex;
  align-items: center;
  justify-content: center;

}

.circle-ripple {
  background-color: #35ffc3;
  width: 1em;
  height: 1em;
  border-radius: 50%;
}
.ripple {
    -webkit-animation: ripple 0.7s linear;
          animation: ripple 0.7s linear;
  animation-duration:0.5s;

}
@-webkit-keyframes ripple {
  0% {
    box-shadow: 0 0 0 0 rgba(101, 255, 120, 0.3), 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3);
  }
  100% {
    box-shadow: 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3), 0 0 0 8em rgba(101, 255, 120, 0);
  }
}

@keyframes ripple {
  0% {
    box-shadow: 0 0 0 0 rgba(101, 255, 120, 0.3), 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3);
  }
  100% {
    box-shadow: 0 0 0 1em rgba(101, 255, 120, 0.3), 0 0 0 3em rgba(101, 255, 120, 0.3), 0 0 0 5em rgba(101, 255, 120, 0.3), 0 0 0 8em rgba(101, 255, 120, 0);
  }
}
<div class="circle-ripple"></div>

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
0 голосов
/ 02 мая 2019

Я думаю, что вы должны удалить класс после определенного времени ожидания.

$(document).ready(function(){
  $(".circle-ripple").click(function(){
    var selector = $(this);
    selector.addClass("ripple");
    setTimeout(function() { 
      selector.removeClass("ripple");
      }, 2000);
  });
});

Установите значение времени ожидания как ваше желание.Надеюсь, что это помогает.

ответ редактируется после комментария от Nuhman.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...