CSS动画onclick并反向下一次onclick

时间:2015-01-15 11:42:52

标签: css css-animations

我正在使用spritesheet和关键帧在单击按钮时为其设置动画。

单击按钮时,我希望框架在一个方向上运行,并将按钮保留在spritesheet中的最后一个图像上,再次单击时,我希望相同的框架向后运行,将按钮保留在第一个spritesheet上的图像。

我目前正在尝试使用jquery将按钮上的类更改为动画类,但这似乎没有效果。

小提琴:http://jsfiddle.net/CGmCe/10295/

JS:

function animate(){
    $('.hi').addClass('animate-hi');
}

CSS:

.hi {
width: 50px;
height: 72px;
background-image: url("http://s.cdpn.io/79/sprite-steps.png");
}

.animate-hi {
    animation: play 2s steps(10);
}

@keyframes play {
   from { background-position:    0px; }
     to { background-position: -500px; }
}

2 个答案:

答案 0 :(得分:4)

确保您使用的是支持动画的浏览器。对我来说,这适用于Firefox。

以下可能就是您想要的:

http://jsfiddle.net/CGmCe/10299/

代码:

function animateButton() {
  var button = $('.hi');
  if (button.hasClass('animate-hi')) {
    button.removeClass('animate-hi').addClass('animate-hi-reverse');
  } else if (button.hasClass('animate-hi-reverse')) {
    button.removeClass('animate-hi-reverse').addClass('animate-hi');
  } else {
    button.addClass('animate-hi');
  }
};
$(document).ready(function() {
  $('.hi').on("click", function() {
    animateButton();
  });
});
.hi {
  width: 50px;
  height: 72px;
  background-image: url("http://s.cdpn.io/79/sprite-steps.png");
}

.animate-hi {
  animation: play 2s steps(10);
}

.animate-hi-reverse {
  animation: play-reverse 2s steps(10);
}

@keyframes play {
  from {
    background-position: 0px;
  }
  to {
    background-position: -500px;
  }
}

@keyframes play-reverse {
  from {
    background-position: -500px;
  }
  to {
    background-position: 0px;
  }
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<img src="http://s.cdpn.io/79/sprite-steps.png" />
<button class="hi" type="button"></button>

答案 1 :(得分:0)

创建一个计数器变量,用于检查是否单击了该按钮。 并且基于计数器值将类添加到元素中,例如:

 var counter=0;
 $('.btn').on('click',function(){
  if(counter=0)
   {
     $('.hi').addClass('animate-hi');
     counter = 1;
   }
  else
   {
        counter = 0;
       $('.hi').removeClass('animate-hi');
   }
 });

确保在函数外声明计数器变量。每次将其值初始化为0时。