jQuery队列控制方法详解queue()/dequeue()/clearQueue()


Posted in Javascript onDecember 02, 2010

先解释一下这组方法各自的含义.
queue(name,[callback]): 当只传入一个参数时, 它返回并指向第一个匹配元素的队列(将是一个函数数组,队列名默认是fx); 当有两个参数传入时, 第一个参数还是默认为fx的的队列名, 第二个参数又分两种情况, 当第二个参数是一个函数时, 它将在匹配的元素的队列最后添加一个函数. 当第二个参数是一个函数数组时,它将匹配元素的队列用新的一个队列来代替(函数数组).可能, 这个理解起来有点晕, 稍后, 后面会有点此查看DEMO.

dequeue(name): 这个好理解, 就是从队列最前端移除一个队列函数, 并执行它.
clearQueue([queueName]):这是1.4新增的方法. 清空对象上尚未执行的所有队列. 参数可选,默认为fx. 但个人觉得这个方法没多大用, 用queue()方法传入两个参数的第二种参数即可实现clearQueue方法.
现在, 我们要实现这样一个效果, 有标有1至7的数字方块, 要求这七个方块自左到右依次下落.点此查看DEMO

jQuery队列控制方法详解queue()/dequeue()/clearQueue()

css与html部分我就不贴出来了,DEMO演示中有. 若按常规做法, 可能需要用如下jQ代码来实现:

$('.one').delay(500).animate({top:'+=270px'},500,function(){
		$('.two').delay(500).animate({top:'+=270px'},500,function(){
			$('.three').delay(500).animate({top:'+=270px'},500,function(){
				$('.four').delay(500).animate({top:'+=270px'},500,function(){
					$('.five').delay(500).animate({top:'+=270px'},500,function(){
						$('.six').delay(500).animate({top:'+=270px'},500,function(){
							$('.seven').animate({top:'+=270px'},500,function(){
								alert('按序落体运动结束! Yeah!')
							});
						});
					});
				});
			});
		});
	});

嗯, 没错, 效果很完美的呈现给出来了, 但这种晕眩的代码, 你能忍受吗? 即便可以忍受, 如果此时, 你想调换一个某个的执行顺序, 比如, 你想让5落下后再开始下落3, 或者新加8至15八个方块, 怎么办? 重写吗? 在里面小心冀冀的改吗? 显然, 我们需要另外一种列简明便捷的方法来实现这个效果, 那就是jQuery队列控制方法.请看如下代码:

var _slideFun=[
	function(){$('.one').delay(500).animate({top:'+=270px'},500,_takeOne);},
	function(){$('.two').delay(300).animate({top:'+=270px'},500,_takeOne);},
	function(){$('.three').delay(300).animate({top:'+=270px'},500,_takeOne);},
	function(){$('.four').delay(300).animate({top:'+=270px'},500,_takeOne);},
	function(){$('.five').delay(300).animate({top:'+=270px'},500,_takeOne);},
	function(){$('.six').delay(300).animate({top:'+=270px'},500,_takeOne);},
	function(){$('.seven').delay(300).animate({top:'+=270px'},500,function(){
		alert('按序落体运动结束! Yeah!');
	});}
];
$('#demo').queue('slideList',_slideFun);
var _takeOne=function(){
	$('#demo').dequeue('slideList');
};
_takeOne();

这样一来, 看起来是不是简明多了. 如何实现?
1. 新建一个数组,把动画函数依次放进去(这样更改顺序,新加动画是不是方便多了?);
2. 用queue将这组动画函数数组加入到slideList队列中;
3. 用dequeue取出slideList队列中第一个函数, 并执行它;
4. 初始执行第一个函数.
DEMO演示中也有详解的注释, 如果上面的说明还看不明白,请看源码.
至于clearQueue()方法,就不多说了, 演示中停止按钮调用的就是clearQueue()方法,当然你还可以用queue()方法直接将现在的函数列队替换成[]空数组实现(个人比较推荐空数组替换.,更直观).

Javascript 相关文章推荐
用js实现计算加载页面所用的时间
Apr 02 Javascript
jquery按回车提交数据的代码示例
Nov 05 Javascript
页面定时刷新(1秒刷新一次)
Nov 22 Javascript
jquery sortable的拖动方法示例详解
Jan 16 Javascript
jquery任意位置浮动固定层插件用法实例
May 29 Javascript
jquery实现的代替传统checkbox样式插件
Jun 19 Javascript
谈谈我对JavaScript中typeof和instanceof的深入理解
Dec 25 Javascript
jQuery实现简单的DIV拖动效果
Feb 19 Javascript
js创建jsonArray传输至后台及后台全面解析
Apr 11 Javascript
Bootstrap 网格系统布局详解
Mar 19 Javascript
bootstrap table表格使用方法详解
Apr 26 Javascript
Node.JS文件系统解析实例详解
May 15 Javascript
JQuery 弹出框定位实现方法
Dec 02 #Javascript
Jquery replace 字符替换实现代码
Dec 02 #Javascript
jquery json 实例代码
Dec 02 #Javascript
JavaScript格式化数字的函数代码
Nov 30 #Javascript
JavaScript中使用正则匹配多条,且获取每条中的分组数据
Nov 30 #Javascript
基于prototype扩展的JavaScript常用函数库
Nov 30 #Javascript
关于UTF-8的客户端用AJAX方式获取GB2312的服务器端乱码问题的解决办法
Nov 30 #Javascript
You might like
一个用php3编写的简单计数器
2006/10/09 PHP
php获取网页上所有链接的方法
2015/04/03 PHP
php实现的用户查询类实例
2015/06/18 PHP
PHP Static延迟静态绑定用法分析
2016/03/16 PHP
Laravel学习教程之request validation的编写
2017/10/25 PHP
Prototype使用指南之base.js
2007/01/10 Javascript
JQuery 选择器 xpath 语法应用
2010/05/13 Javascript
基于Jquery+Ajax+Json的高效分页实现代码
2011/10/29 Javascript
JavaScript中将一个值转换为字符串的方法分析[译]
2012/09/21 Javascript
用javascript添加控件自定义属性解析
2013/11/25 Javascript
影响jQuery使用的14个方面
2014/09/01 Javascript
介绍一个简单的JavaScript类框架
2015/06/24 Javascript
JavaScript中的this引用(推荐)
2016/08/05 Javascript
Vue利用canvas实现移动端手写板的方法
2018/05/03 Javascript
JS中Promise函数then的奥秘探究
2018/07/30 Javascript
JS使用数组实现的队列功能示例
2019/03/04 Javascript
小程序关于请求同步的总结
2019/05/05 Javascript
Node.js API详解之 string_decoder用法实例分析
2020/04/29 Javascript
vue+element-ui JYAdmin后台管理系统模板解析
2020/07/28 Javascript
在Django的模型和公用函数中使用惰性翻译对象
2015/07/27 Python
深度定制Python的Flask框架开发环境的一些技巧总结
2016/07/12 Python
window下eclipse安装python插件教程
2017/04/24 Python
用python生成1000个txt文件的方法
2018/10/25 Python
Python时间序列处理之ARIMA模型的使用讲解
2019/04/02 Python
Python中sorted()排序与字母大小写的问题
2020/01/14 Python
用python查找统一局域网下ip对应的mac地址
2021/01/13 Python
Python 转移文件至云对象存储的方法
2021/02/07 Python
CSS3实现简易版的刮刮乐效果
2016/09/27 HTML / CSS
CSS3 文字动画效果
2020/11/12 HTML / CSS
定制别致的瑜伽垫:Sugarmat
2019/06/21 全球购物
Roxy俄罗斯官方网站:冲浪和滑雪板的一切
2020/06/20 全球购物
大学生演讲稿范文
2014/01/11 职场文书
房屋出租协议书
2014/04/10 职场文书
幼儿园保教工作总结2015
2015/10/15 职场文书
晶体管单管来复再生式收音机
2021/04/22 无线电
微软发布Windows 11今年最大更新22H2(附 ISO 镜像官方下载)
2022/09/23 数码科技