用css3实现当鼠标移动到div时,div抖动
工具/原料首先,新建一个只有div的页面,并加上适当的样式
data:image/s3,"s3://crabby-images/974b5/974b589030ef3c5a7a2af7e765faeed562eebff3" alt="css3实现抖动效果"
data:image/s3,"s3://crabby-images/578ec/578ec14fed3aa191e7f40b6f11b04bfb92a5e45f" alt="css3实现抖动效果"
抖动效果需要用到animation属性,首先先加一个keyframes,我用的是chrome浏览器所以要加上-webkit前缀
@-webkit-keyframes buzz-out {
0% {
-webkit-transform: translateX(3px) rotate(2deg);
}
100% {
-webkit-transform: translateX(-3px) rotate(-2deg);
}
}
0% 是动画的开始时间,而100% 动画的结束时间。
data:image/s3,"s3://crabby-images/5a11d/5a11d5123541d7a5c766c753df2c5597a3a3d1b4" alt="css3实现抖动效果"
然后加上hover
#buzz:hover {
-webkit-animation-name: buzz-out;
-webkit-animation-duration: 0.75s;
-webkit-animation-timing-function: linear;
-webkit-animation-iteration-count: 1;
}
data:image/s3,"s3://crabby-images/6b963/6b9637c5e216b99a29dc174e7b5f07105e193d1c" alt="css3实现抖动效果"
然后当鼠标移到div上就会看到有摇晃的效果
data:image/s3,"s3://crabby-images/0c595/0c595ae38726b3c73124b1758041d1acc60c143b" alt="css3实现抖动效果"
如何实现抖动?
就要把@-webkit-keyframes buzz-out更细化,比如下图,这样就能抖起来了。
data:image/s3,"s3://crabby-images/756e5/756e5d3f7d55ad294eb6c20a8950adbd221a07a3" alt="css3实现抖动效果"