jQuery队列操作方法实例


Posted in Javascript onJune 11, 2014

jQuery核心中, 有一组队列控制方法, 这组方法由queue()/dequeue()/clearQueue()三个方法组成, 它对需要连续按序执行的函数的控制可以说是简明自如, 主要应用于animate ()方法, ajax以及其他要按时间顺序执行的事件中.

先解释一下这组方法各自的含义.

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

dequeue(name): 这个好理解, 就是从队列最前端移除一个队列函数, 并执行它.

clearQueue([queueName]):这是1.4新增的方法. 清空对象上尚未执行的所有队列. 参数可选,默认为fx. 但个人觉得这个方法没多大用, 用queue()方法传入两个参数的第二种参数即可实现clearQueue方法.

现在, 我们要实现这样一个效果, 有标有1至7的数字方块, 要求这七个方块自左到右依次下落. 查看DEMO
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. 初始执行第一个函数.

至于clearQueue()方法,就不多说了, 演示中停止按钮调用的就是clearQueue()方法,当然你还可以用queue()方法直接将现在的函数列队替换成[]空数组实现(个人比较推荐空数组替换.,更直观).

Javascript 相关文章推荐
表单(FORM)的一些实用效果代码
Mar 25 Javascript
一个简单的js树形菜单
Dec 09 Javascript
深入理解JavaScript系列(34):设计模式之命令模式详解
Mar 03 Javascript
javascript中tostring()和valueof()的用法及两者的区别
Nov 16 Javascript
JavaScript实现字符串与日期的互相转换及日期的格式化
Mar 07 Javascript
关于javascript原型的修改与重写(覆盖)差别详解
Aug 31 Javascript
AngularJS自定义插件实现网站用户引导功能示例
Nov 07 Javascript
过期软件破解办法实例详解
Jan 04 Javascript
jackson解析json字符串,首字母大写会自动转为小写的方法
Dec 22 Javascript
vue移动端路由切换实例分析
May 14 Javascript
利用原生JavaScript实现造日历轮子实例代码
May 08 Javascript
微信小程序实现列表滚动头部吸顶的示例代码
Jul 12 Javascript
JS生成不重复随机数组的函数代码
Jun 10 #Javascript
JS 在指定数组中随机取出N个不重复的数据
Jun 10 #Javascript
JS生成随机字符串的多种方法
Jun 10 #Javascript
json中换行符的处理方法示例介绍
Jun 10 #Javascript
Jquery焦点与失去焦点示例应用
Jun 10 #Javascript
浅析基于WEB前端页面的页面内容搜索的实现思路
Jun 10 #Javascript
JavaScript中统计Textarea字数并提示还能输入的字符
Jun 10 #Javascript
You might like
上海永华YH-R296(华普R-96)12波段立体声收音机的分析和打理
2021/03/02 无线电
获得Google PR值的PHP代码
2007/01/28 PHP
php读取mysql的简单实例
2014/01/15 PHP
浅谈php安全性需要注意的几点事项
2014/07/17 PHP
php中实现获取随机数组列表的自定义函数
2015/04/02 PHP
初识PHP中的Swoole
2016/04/05 PHP
php封装的page分页类完整实例
2016/10/18 PHP
thinkPHP简单导入和使用阿里云OSSsdk的方法
2017/03/15 PHP
Ajax请求PHP后台接口返回信息的实例代码
2018/08/21 PHP
js解决弹窗问题实现班级跳转DIV示例
2014/01/06 Javascript
常用jQuery选择器总结
2014/07/11 Javascript
jQuery实现瀑布流的取巧做法分享
2015/01/12 Javascript
jQuery实现Meizu魅族官方网站的导航菜单效果
2015/09/14 Javascript
JS生成某个范围的随机数【四种情况详解】
2016/04/20 Javascript
谈谈target=_new和_blank的不同之处
2016/10/25 Javascript
Vue 2.0双向绑定原理的实现方法
2019/10/23 Javascript
小程序实现图片预览裁剪插件
2019/11/22 Javascript
解决echarts中横坐标值显示不全(自动隐藏)问题
2020/07/20 Javascript
Python with的用法
2014/08/22 Python
python服务器与android客户端socket通信实例
2014/11/12 Python
Python标准模块--ContextManager上下文管理器的具体用法
2017/11/27 Python
利用numpy实现一、二维数组的拼接简单代码示例
2017/12/15 Python
python面向对象多线程爬虫爬取搜狐页面的实例代码
2018/05/31 Python
使用Python Pandas处理亿级数据的方法
2019/06/24 Python
解决Django migrate不能发现app.models的表问题
2019/08/31 Python
Python实现钉钉订阅消息功能
2020/01/14 Python
python库skimage给灰度图像染色的方法示例
2020/04/27 Python
应届毕业生如何写求职信
2014/02/16 职场文书
大学生简历求职信
2014/06/24 职场文书
效能风暴心得体会
2014/09/04 职场文书
五年级上册复习计划
2015/01/19 职场文书
大学生自荐书范文
2015/03/05 职场文书
2015年万圣节活动总结
2015/03/24 职场文书
惹女朋友生气检讨书
2015/05/06 职场文书
MySQL sql_mode的使用详解
2021/05/08 MySQL
MySQL中varchar和char类型的区别
2021/11/17 MySQL