CSS3转换点击使用纯CSS

前端之家收集整理的这篇文章主要介绍了CSS3转换点击使用纯CSS前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想要获得一个图像(加号)旋转45度以创建交叉符号。我到目前为止使用下面的代码来实现这一点,但是它的工作在悬停,我想让它旋转点击。

有没有一个简单的方法来使用CSS?

我的代码是:

CSS

  1. img {
  2. display: block;
  3. margin: 20px;
  4. }
  5.  
  6. .crossRotate {
  7. -webkit-transition-duration: 1s;
  8. -moz-transition-duration: 1s;
  9. -o-transition-duration: 1s;
  10. transition-duration: 1s;
  11. -webkit-transition-property: -webkit-transform;
  12. -moz-transition-property: -moz-transform;
  13. -o-transition-property: -o-transform;
  14. transition-property: transform;
  15. }
  16.  
  17. .crossRotate:hover {
  18. -webkit-transform: rotate(45deg);
  19. -ms-transform: rotate(45deg);
  20. transform: rotate(45deg);
  21. }

HTML

  1. <body>
  2. <img class="crossRotate" src="images/cross.png" alt="Cross Menu button" />
  3. </body>

这是jsfiddle演示。

解决方法

如果你想要一个只有CSS的解决方案,你可以使用 active
  1. .crossRotate:active {
  2. transform: rotate(45deg);
  3. -webkit-transform: rotate(45deg);
  4. -ms-transform: rotate(45deg);
  5. }

但是,当活动移动时,转换将不会持续。为此,您需要javascript(jquery clickcss是最干净的IMO)。

  1. $( ".crossRotate" ).click(function() {
  2. if ( $( this ).css( "transform" ) == 'none' ){
  3. $(this).css("transform","rotate(45deg)");
  4. } else {
  5. $(this).css("transform","" );
  6. }
  7. });

Fiddle

猜你在找的CSS相关文章