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 学习点滴记录
Apr 24 Javascript
用js获取电脑信息(是使用与IE浏览器)
Jan 15 Javascript
jQuery使用技巧简单汇总
Apr 18 Javascript
javascript一元操作符(递增、递减)使用示例
Aug 07 Javascript
jquery通过load获取文件的内容并跳到锚点的方法
Jan 29 Javascript
vue.js路由跳转详解
Aug 28 Javascript
React中嵌套组件与被嵌套组件的通信过程
Jul 11 Javascript
JavaScript作用域、闭包、对象与原型链概念及用法实例总结
Aug 20 Javascript
基于iview的router常用控制方式
May 30 Javascript
vue实现简单瀑布流布局
May 28 Javascript
Nuxt配置Element-UI按需引入的操作方法
Jul 06 Javascript
Vue.js中v-for指令的用法介绍
Mar 13 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
利用Homestead快速运行一个Laravel项目的方法详解
2017/11/14 PHP
Laravel 已登陆用户再次查看登陆页面的自动跳转设置方法
2019/09/30 PHP
jQuery实现的Email中的收件人效果(按del键删除)
2011/03/20 Javascript
js动态加载以及确定加载完成的代码
2011/07/31 Javascript
javascript数据结构与算法之检索算法
2015/04/04 Javascript
JQuery查找DOM节点的方法
2015/06/11 Javascript
Angularjs注入拦截器实现Loading效果
2015/12/28 Javascript
Jquery实现遮罩层的简单实例(就是弹出DIV周围都灰色不能操作)
2016/07/14 Javascript
深入浅析javascript中的作用域(推荐)
2016/07/19 Javascript
jQuery实现智能判断固定导航条或侧边栏的方法
2016/09/04 Javascript
javascript表单正则应用
2017/02/04 Javascript
three.js绘制地球、飞机与轨迹的效果示例
2017/02/28 Javascript
js实现上下左右弹框划出效果
2017/03/08 Javascript
JavaScript继承与多继承实例分析
2018/05/26 Javascript
ES6与CommonJS中的模块处理的区别
2018/06/13 Javascript
vue-cli3+typescript初体验小结
2019/02/28 Javascript
JS/CSS实现字符串单词首字母大写功能
2019/09/03 Javascript
关于layui 实现点击按钮添加一行(方法渲染创建的table)
2019/09/29 Javascript
微信小程序自定义组件components(代码详解)
2019/10/21 Javascript
Django查询数据库的性能优化示例代码
2017/09/24 Python
答题辅助python代码实现
2018/01/16 Python
Python之inspect模块实现获取加载模块路径的方法
2018/10/16 Python
Python数据分析:手把手教你用Pandas生成可视化图表的教程
2018/12/15 Python
Python实现使用request模块下载图片demo示例
2019/05/24 Python
Python 3.8正式发布,来尝鲜这些新特性吧
2019/10/15 Python
通过实例了解python property属性
2019/11/01 Python
Python读取文件内容为字符串的方法(多种方法详解)
2020/03/04 Python
python爬虫容易学吗
2020/06/02 Python
利用html5的websocket实现websocket聊天室
2013/12/12 HTML / CSS
浅析图片上传及canvas压缩的流程
2020/06/10 HTML / CSS
Mio Skincare中文官网:肌肤和身体护理
2016/10/26 全球购物
英国综合网上购物商城:The Hut
2018/07/03 全球购物
《孔子拜师》教学反思
2014/02/24 职场文书
探亲假请假条
2014/04/11 职场文书
小兵张嘎观后感
2015/06/03 职场文书
mysql优化
2021/04/06 MySQL