Jquery如何使用animation动画效果改变背景色
Jquery如何使用animation动画效果改变背景色
一、问题引入
-
jquery的animate动画虽然强大,但是无法使用其进行背景色(background-color)的动画效果变化,因为animate动画效果只能动态改变数值型的参数,例如:top,left,width,height...等等
好像网上也有说要装一个 "jquery.ui" 的插件之类的。但是博主我实在不想引入过多的插件,且恰好本人掌握的CSS比较好一点点,所以就想了下面这么个法子。
-
但好在 CSS 它自带的animation动画效果更加强大,它可以为我们提供背景色的动态变化。所以我们可以利用Js+CSS 的方法达成我们预期效果。
二、demo展示
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Jquery无法通过animate动画改变背景色</title>
<style type="text/css">
#btn{
display: block;
width:100px;
margin:50px auto 0px;
font:bold 30px/50px 'Microsoft Yahei';
background-color: lightblue;
}
.box{
margin:100px auto 0px;
background-color: green;
width:400px;
height:400px;
}
@keyframes color_turn{
from{
background-color: green;
}
to{
background-color: blue;
}
}
.change_color{
animation: color_turn 500ms ease 2 alternate;
}
</style>
<script type="text/javascript" src="js/jquery-1.12.4.min.js"></script>
<script type="text/javascript">
$(function(){
var obtn = $('#btn');
var obox = $('.box');
obtn.click(function(){
/*
由于需要动画能够重复播放,所以我们需要反复删除和添加 change_color 这个类,
按照正常逻辑,先删除该类,再添加应当会正常播放动画,
但经多次试验只有第一次触发能够播放变色动画,接着再也无法触发了。这是由于两句执行的时间间隔太小,导致出现bug,无法达到预期效果
所以我们要想办法让下面这两句代码执行的时间间隔长一点
obox.removeClass('change_color');
obox.addClass('change_color');
*/
obox.removeClass('change_color');
// obox.addClass('change_color');
/*----通过定时器延迟 10ms 后执行移除类的指令,这样就能解决问题了-----*/
var timer = setTimeout(function(){
obox.addClass('change_color');
},10);
})
})
</script>
</head>
<body>
<input type="button" id="btn" value="变色">
<div class="box"></div>
</body>
</html>
2.1 程序设计思想
- 首先设计好一个由绿色变为蓝色的动画效果,使用一个类名为 "change_color" 的选择器来存放。
- 通过 js 实现点击按钮一次,先对div 标签清除类名为 "change_color" 的类(第一次触发没有该类,不用管),当定时器,经过 10ms 后会执行添加该类的命令,增加类后,动画便开始播放。通过定时器延长了两句代码的间隔时间,使得点击按钮可以重复播放背景色变化的动画效果。
2.2 重点与难点(坑)
-
之所以,要使用定时器来添加 "change_color" 这个类,是因为如果移除类与增加类两句代码 挨得太近,会导致bug,即无法实现重复点击按钮,反复播放动画。
具体原因尚不明确,但猜测是因为判定移除该类的程序需要的时间长,所以两句代码放太近,会导致最后只判定到该类还存在(即没有移除过),而已有的类是不会触发动画的(只有在原来没有该类的基础上,添加类后,才会触发动画且只播放一次)
所以为了能够重复播放,需要反复删除和添加类,同时由于两句执行时间间隔不能太小,所以设置了一个定时器,使得 10ms 后才执行添加类,保证程序能够成功判定类已被移除过。别看 10ms 很小,里面的机器周期数是巨多的 -
其实还有一种方式,但前提是 中间的代码足够长 (即机器周期足够长)
obtn.click(function(){ obox.removeClass('change_color'); ... ... ... obox.addClass('change_color'); })
每次点击,播放动画前先移除类,经过若干个机器周期(究竟多少个,代码要多长,我也不清楚),再增加该类,便能达到预期效果。