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 相关文章推荐
javascript 一段左右两边随屏滚动的代码
Jun 18 Javascript
JavaScript中SQL语句的应用实现
May 04 Javascript
jQuery中prevAll()方法用法实例
Jan 08 Javascript
javascript显示中文日期的方法
Jun 18 Javascript
jQuery 1.9.1源码分析系列(十)事件系统之主动触发事件和模拟冒泡处理
Nov 24 Javascript
javascript判断图片是否加载完成的方法推荐
May 13 Javascript
Bootstrap组件系列之福利篇几款好用的组件(推荐二)
Jul 12 Javascript
JS制作类似选项卡切换的年历
Dec 03 Javascript
js 轮播效果实例分享
Dec 28 Javascript
angular+ionic 的app上拉加载更新数据实现方法
Jan 16 Javascript
浅谈用Webpack路径压缩图片上传尺寸获取的问题
Feb 22 Javascript
vue实现拖拽进度条
Mar 01 Vue.js
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
不用mod_rewrite直接用php实现伪静态化页面代码
2008/10/04 PHP
php数组函数序列之array_splice() - 在数组任意位置插入元素
2011/11/07 PHP
Laravel如何使用数据库事务及捕获事务失败后的异常详解
2017/10/23 PHP
PHP抽象类与接口的区别实例详解
2019/05/09 PHP
Prototype1.6 JS 官方下载地址
2007/11/30 Javascript
JS 的应用开发初探(mootools)
2009/12/19 Javascript
创建公共调用 jQuery Ajax 带返回值
2012/08/01 Javascript
JS异常处理的一个想法(sofish)
2013/03/14 Javascript
node.js中的querystring.stringify方法使用说明
2014/12/10 Javascript
JavaScript中的原型prototype属性使用详解
2015/06/05 Javascript
微信小程序 swiper组件轮播图详解及实例
2016/11/16 Javascript
原生js实现可拖动的登录框效果
2017/01/21 Javascript
js 实现获取name 相同的页面元素并循环遍历的方法
2017/02/14 Javascript
JavaScript的继承实现小结
2017/05/07 Javascript
深入浅析Vue中的slots/scoped slots
2018/04/03 Javascript
nodejs 日志模块winston的使用方法
2018/05/02 NodeJs
p5.js实现动态图形临摹
2019/10/23 Javascript
Angular8 实现table表格表头固定效果
2020/01/03 Javascript
创建nuxt.js项目流程图解
2020/03/13 Javascript
使用next.js开发网址缩短服务的方法
2020/06/17 Javascript
JavaScript函数柯里化实现原理及过程
2020/12/02 Javascript
Python读写unicode文件的方法
2015/07/10 Python
python实现百度语音识别api
2018/04/10 Python
python 实现屏幕录制示例
2019/12/23 Python
pytorch的梯度计算以及backward方法详解
2020/01/10 Python
Python的赋值、深拷贝与浅拷贝的区别详解
2020/02/12 Python
python自动从arxiv下载paper的示例代码
2020/12/05 Python
AmazeUI 按钮交互的实现示例
2020/08/24 HTML / CSS
珠宝店促销方案
2014/03/21 职场文书
万里长城导游词
2015/01/30 职场文书
施工安全责任协议书
2016/03/23 职场文书
Python数据分析之绘图和可视化详解
2021/06/02 Python
CSS使用伪类控制边框长度的方法
2022/01/18 HTML / CSS
一文了解MySQL二级索引的查询过程
2022/02/24 MySQL
MyBatis配置文件解析与MyBatis实例演示
2022/04/07 Java/Android
HTML静态页面获取url参数和UserAgent的实现
2022/08/05 HTML / CSS