Jquery如何使用animation动画效果改变背景色的代码


Posted in jQuery onJuly 20, 2020

 一、问题引入

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.addClass('change_color');
					/*----通过定时器延迟 1100ms 后执行移除类的指令,这样就能解决问题了-----*/
					var timer = setTimeout(function(){
						obox.removeClass('change_color');
					},1100);

				})

			})

		</script>

	</head>
	<body>
		<input type="button" id="btn" value="变色">
		<div class="box"></div>
	</body>
</html>

2.1 程序设计思想

  • 首先设计好一个由绿色变为蓝色的动画效果,使用一个类名为 "change_color" 的选择器来存放。
  • 通过 js 实现点击按钮一次,为 div 标签 增加类名为 "change_color" 的类,增加完后,动画便开始播放。 当定时器,经过 1100ms 后会执行移除该类的命令, 使得点击按钮可以重复播放背景色变化的动画效果。

2.2 重点与难点(坑)

之所以,要使用定时器来移除 "change_color" 这个类,是因为如果增加类与移除类两句代码 挨得太近 ,会导致bug,即无法实现重复点击按钮,实现反复播放动画。所以为了能够重复播放,且两句执行时间间隔不能太小,所以设置了一个定时器,使得 1100ms 后执行 (定时器的时间还得根据你的动画持续时间而定,保证动画播放完以后,再进行类的移除)

其实还有一种方式,但前提是 中间的代码足够长 (即机器周期足够长)

obtn.click(function(){
			
			obox.removeClass('change_color');
			...
			...
			...
			obox.addClass('change_color');
})

每次点击,播放动画前先移除类,经过若干个机器周期( 究竟多少个,代码要多长,我也不清楚 ),再增加该类,便能达到预期效果。

2.3 效果展示

Jquery如何使用animation动画效果改变背景色的代码

到此这篇关于Jquery如何使用animation动画效果改变背景色的文章就介绍到这了,更多相关Jquery如何使用animation动画效果改变背景色内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

jQuery 相关文章推荐
jQuery输入框密码的显示隐藏【代码分享】
Apr 29 jQuery
jquery.guide.js新版上线操作向导镂空提示jQuery插件(推荐)
May 20 jQuery
jQuery实现动态删除LI的方法
May 30 jQuery
jQuery用户头像裁剪插件cropbox.js使用详解
Jun 07 jQuery
jQuery实现 RadioButton做必选校验功能
Jun 15 jQuery
jQuery序列化后的表单值转换成Json
Jun 16 jQuery
关于jquery form表单序列化的注意事项详解
Aug 01 jQuery
基于JQuery的Ajax方法使用详解
Aug 16 jQuery
jQueryMobile之窗体长内容的缺陷与解决方法实例分析
Sep 20 jQuery
jQuery实现的简单歌词滚动功能示例
Jan 07 jQuery
AJAX在JQuery中的应用详解
Jan 30 jQuery
基于JQuery和DWR实现异步数据传递
Oct 16 jQuery
jquery实现有过渡效果的tab切换
Jul 17 #jQuery
jQuery加PHP实现图片上传并提交的示例代码
Jul 16 #jQuery
jQuery 添加元素和删除元素的方法
Jul 15 #jQuery
Jquery使用each函数实现遍历及数组处理
Jul 14 #jQuery
jQuery 实现DOM元素拖拽交换位置的实例代码
Jul 14 #jQuery
jQuery开发仿QQ版音乐播放器
Jul 10 #jQuery
jQuery实现B2B网站后台管理系统侧导航
Jul 08 #jQuery
You might like
如何在PHP中使用Oracle数据库(1)
2006/10/09 PHP
php使用Cookie实现和用户会话的方法
2015/01/21 PHP
[原创]PHP实现生成vcf vcard文件功能类定义与使用方法详解【附demo源码下载】
2017/09/02 PHP
简单的php购物车代码
2020/06/05 PHP
js压缩利器
2007/02/20 Javascript
JavaScript 字符串与数组转换函数[不用split与join]
2009/12/13 Javascript
用javascript替换URL中的参数值示例代码
2014/01/27 Javascript
jQuery学习笔记之toArray()
2014/06/09 Javascript
vue实现ajax滚动下拉加载,同时具有loading效果(推荐)
2017/01/11 Javascript
Bootstrap超大屏幕的实现代码
2017/03/22 Javascript
微信小程序实现多宫格抽奖活动
2020/04/15 Javascript
搭建一个Koa后端项目脚手架的方法步骤
2019/05/30 Javascript
基于Bootstrap和JQuery实现动态打开和关闭tab页的实例代码
2019/06/10 jQuery
taro 实现购物车逻辑的实例代码
2020/06/05 Javascript
如何在vue中使用video.js播放m3u8格式的视频
2021/02/01 Vue.js
Python简单计算文件夹大小的方法
2015/07/14 Python
Python错误处理操作示例
2018/07/18 Python
Python使用sax模块解析XML文件示例
2019/04/04 Python
pytorch 实现模型不同层设置不同的学习率方式
2020/01/06 Python
python3 使用openpyxl将mysql数据写入xlsx的操作
2020/05/15 Python
python怎么删除缓存文件
2020/07/19 Python
使用CSS3实现圆角,阴影,透明
2014/12/23 HTML / CSS
html5 canvas fillRect坐标和大小的问题解决方法
2014/03/26 HTML / CSS
详解html5 shiv.js和respond.min.js
2018/01/24 HTML / CSS
HTML5实现移动端点击翻牌功能
2020/10/23 HTML / CSS
美国专营婴幼儿用品的购物网站:buybuy BABY
2017/01/01 全球购物
馥蕾诗美国官网:Fresh美国
2019/10/09 全球购物
旅游业大学生创业计划书
2014/01/31 职场文书
应届电子商务毕业自荐书范文
2014/02/11 职场文书
学位证书委托书
2014/09/30 职场文书
皇城相府导游词
2015/02/06 职场文书
辩论赛主持人开场白
2015/05/29 职场文书
2015年秋学期教研工作总结
2015/10/14 职场文书
合作意向书怎么写
2019/06/24 职场文书
创业计划书之电动车企业
2019/10/11 职场文书
Win11快速关闭所有广告推荐
2022/04/19 数码科技