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 相关文章推荐
基于jquery用于查询操作的实现代码
May 10 Javascript
stream.js 一个很小、完全独立的Javascript类库
Oct 28 Javascript
JavaScript中常用的运算符小结
Jan 18 Javascript
ajax不执行success回调而是执行了error回调
Dec 10 Javascript
浅谈JavaScript之事件绑定
Jul 08 Javascript
jQuery对checkbox 复选框的全选全不选反选的操作
Aug 09 Javascript
Angular.JS实现无限级的联动菜单(使用demo)
Feb 08 Javascript
使用JavaScript实现一个小程序之99乘法表
Sep 21 Javascript
新手快速入门JavaScript装饰者模式与AOP
Jun 24 Javascript
Vue.js中provide/inject实现响应式数据更新的方法示例
Oct 16 Javascript
如何基于原生javaScript生成带图片的二维码
Nov 21 Javascript
Jquery使用each函数实现遍历及数组处理
Jul 14 jQuery
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
要会喝咖啡也要会知道咖啡豆
2021/03/03 咖啡文化
php强制文件下载而非在浏览器打开的自定义函数分享
2014/05/08 PHP
Codeigniter中集成smarty和adodb的方法
2016/03/04 PHP
PHP实现向关联数组指定的Key之前插入元素的方法
2017/06/06 PHP
JavaScript Distilled 基础知识与函数
2010/04/07 Javascript
麻雀虽小五脏俱全 Dojo自定义控件应用
2010/09/04 Javascript
JavaScript通过prototype给对象定义属性用法实例
2015/03/23 Javascript
详解JavaScript ES6中的Generator
2015/07/28 Javascript
js实现可折叠展开的手风琴菜单效果
2015/09/07 Javascript
javascript设计模式--策略模式之输入验证
2015/11/27 Javascript
使用jQuery的easydrag插件实现可拖动的DIV弹出框
2016/02/19 Javascript
jquery按回车键实现表单提交的简单实例
2016/05/25 Javascript
JS控制静态页面传递参数并获取参数应用
2016/08/10 Javascript
Node.js批量给图片加水印的方法
2016/11/15 Javascript
tab栏切换原理
2017/03/22 Javascript
Three.js入门之hello world以及如何绘制线
2017/09/25 Javascript
利用ECharts.js画K线图的方法示例
2018/01/10 Javascript
小程序实现五星点评效果
2018/11/03 Javascript
[00:30]塑造者的传承礼包-戴泽“暗影之焰”套装展示视频
2014/04/04 DOTA
python局域网ip扫描示例分享
2014/04/03 Python
python根据开头和结尾字符串获取中间字符串的方法
2015/03/26 Python
详解appium+python 启动一个app步骤
2017/12/20 Python
解决tensorflow测试模型时NotFoundError错误的问题
2018/07/26 Python
python 内置模块详解
2019/01/01 Python
如何在python中写hive脚本
2019/11/08 Python
Python实现自动整理文件的脚本
2020/12/17 Python
HTML5 实战PHP之Web页面表单设计
2011/10/09 HTML / CSS
通信工程专业女生个人求职信
2013/09/21 职场文书
大学生的自我鉴定范文
2014/01/21 职场文书
大学毕业生求职自荐信
2014/02/20 职场文书
中学生国旗下讲话稿
2014/04/26 职场文书
机关作风建设自查报告
2014/10/22 职场文书
2014年前台个人工作总结
2014/11/14 职场文书
2014年音乐教师工作总结
2014/12/03 职场文书
2015年超市工作总结
2015/04/09 职场文书
2015年科室工作总结
2015/04/10 职场文书