wake-up-neo.net

CSS-Animation bei Klick

Wie bekomme ich eine CSS-Animation zum Spielen mit einem JavaScript-onClick? Ich habe momentan:

.classname {
  -webkit-animation-name: cssAnimation;
  -webkit-animation-duration:3s;
  -webkit-animation-iteration-count: 1;
  -webkit-animation-timing-function: ease;
  -webkit-animation-fill-mode: forwards;
}
@-webkit-keyframes cssAnimation {
  from {
    -webkit-transform: rotate(0deg) scale(1) skew(0deg) translate(100px);
  }
  to {
    -webkit-transform: rotate(0deg) scale(2) skew(0deg) translate(100px);
  }
}

Wie kann ich einen onClick anwenden?

22
tekknolagi

Sind Sie sicher, dass Sie Ihre Seite nur im Webkit anzeigen? Hier ist der Code, der an Safari übergeben wird ..__ Das Bild (id='img') wird nach dem Klicken der Schaltfläche gedreht.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<style type="text/css">
.classname {
  -webkit-animation-name: cssAnimation;
  -webkit-animation-duration:3s;
  -webkit-animation-iteration-count: 1;
  -webkit-animation-timing-function: ease;
  -webkit-animation-fill-mode: forwards;
}
@-webkit-keyframes cssAnimation {
  from {
    -webkit-transform: rotate(0deg) scale(1) skew(0deg) translate(100px);
  }
  to {
    -webkit-transform: rotate(0deg) scale(2) skew(0deg) translate(100px);
  }
}
</style>
<script type="text/javascript">
  function ani(){
    document.getElementById('img').className ='classname';
  }
</script>
<title>Untitled Document</title>
</head>

<body>
<input name="" type="button" onclick="ani()" />
<img id="img" src="clogo.png" width="328" height="328" />
</body>
</html>
45
Shisoft

Sie können dies erreichen, indem Sie einen Onclick-Listener binden und dann die animierte Klasse wie folgt hinzufügen:

$('#button').onClick(function(){
    $('#target_element').addClass('animate_class_name');
});
13
user472521

Sie verwenden nur die Pseudo-Klasse :active . Dies wird festgelegt, wenn Sie auf ein Element klicken.

.classname:active {
    /* animation css */
}
7
Paul Fisher

Füge hinzu ein 

-webkit-animation-play-state: paused;

in Ihre CSS-Datei können Sie mit dieser JS-Zeile steuern, ob die Animation läuft oder nicht

document.getElementById("myDIV").style.WebkitAnimationPlayState = "running";

wenn Sie möchten, dass die Animation bei jedem Klick einmal ausgeführt wird. Denken Sie daran zu setzen 

-webkit-animation-iteration-count: 1;
1
NoteTheNote

var  abox = document.getElementsByClassName("box")[0];
function allmove(){
        abox.classList.remove("move-ltr");
        abox.classList.remove("move-ttb");
       abox.classList.toggle("move");
}
function ltr(){
        abox.classList.remove("move");
        abox.classList.remove("move-ttb");
       abox.classList.toggle("move-ltr");
}
function ttb(){
       abox.classList.remove("move-ltr");
       abox.classList.remove("move");
       abox.classList.toggle("move-ttb");
}
.box {
  width: 100px;
  height: 100px;
  background: red;
  position: relative;
}
.move{
  -webkit-animation: moveall 5s;
  animation: moveall 5s;
}
.move-ltr{
   -webkit-animation: moveltr 5s;
  animation: moveltr 5s;
}
.move-ttb{
    -webkit-animation: movettb 5s;
  animation: movettb 5s;
}
@keyframes moveall {
  0%   {left: 0px; top: 0px;}
  25%  {left: 200px; top: 0px;}
  50%  {left: 200px; top: 200px;}
  75%  {left: 0px; top: 200px;}
  100% {left: 0px; top: 0px;}
}
@keyframes moveltr {
  0%   { left: 0px; top: 0px;}
  50%  {left: 200px; top: 0px;}
  100% {left: 0px; top: 0px;}
}
@keyframes movettb {
  0%   {left: 0px; top: 0px;}
  50%  {top: 200px;left: 0px;}
  100% {left: 0px; top: 0px;}
}
<div class="box"></div>
<button onclick="allmove()">click</button>
<button onclick="ltr()">click</button>
<button onclick="ttb()">click</button>

0
R.K. Roy

Sie können das tun, indem Sie folgenden Code verwenden

$('#button_id').on('click', function(){
$('#element_want_to_target').addClass('.animation_class');});
0
Junaid

Versuche dies:

<div>
 <p onclick="startAnimation()">Start</p><!--O botão para iniciar (start)-->
 <div id="animation">Hello!</div> <!--O elemento que você quer animar-->
</div>

<style>
@keyframes animationName {
from {margin-left:-30%;}
}
</style>

<script>
function startAnimation() {
    document.getElementById("animation").style.animation = "animationName 2s linear 1";
}
</script>
0
Rafael Santos