jQuery 中的动画队列

动画队列

什么是 jQuery 的动画队列?首先,我们先来了解一下什么是队列。队列是一种特殊的线性表,只允许在表的前端(表头)进行删除操作,在表的后端(表末)进行添加操作,队列的特点是先进先出,最先插入的元素最先被删除。所以,动画队列可以说是动画执行的一个顺序机制,当我们对一个对象添加多次动画效果时后,添加的动作就会被放入这个动画队列中,等前面的动画完成后再开始执行。

动画队列机制的执行顺序

1.对于一组元素上的动画效果,有如下两种情况:
a) 当在一个animate()方法中应用多个属性时,动画是同时发生的;
b)当以链式的写法应用动画方法时,动画是按照顺序发生的。

2.对于多组元素上的动画效果,有如下情况:
a) 默认情况下,动画都是同时发生的;
b) 当以回调的形式应用动画方式时,动画是按照回调顺序发生的。

以上是整个动画的调度一个流程,其实都是利用队列异步的空闲然后执行同步的代码,这样在处理上是没有浪费资源的,而且精确度也是最高的。另外,在动画方法中,要注意其他非动画的方法会插队,例如 css() 方法,要使这些非动画的方法也按照顺序来执行,需要把这些方法写在动画方法的回调函数中。例如:
$("#id").animate({left:"400px", top:"300px"}, 3000, function(){ $(this).css("border", "1px solid blue"); });

与之相关的方法

动画队列中主要用到 jQuery 的 queue、dequeue 和 clearqueue。
1.queue() 方法主要是将一个动画函数数组绑定到一个队列上。例如:
$('#box').animate({'left': '100px'}, 1000).animate({'width': '200px'}, 1000); $('#box').queue(function() { $('#box').css('background', 'lightgreen'); })

2.dequeue() 方法主要是执行队列的第一个函数,并从队列中删除。例如:
$('#box').animate({'left': '100px'}, 1000).animate({'width': '200px'}, 1000); $('#box').queue(function() { $(this).css('background', 'lightgreen'); $(this).dequeue(); })

3.clearqueue() 方法是清除动画队列。例如:
$('#btn1').click(function(event) { $('#box').clearQueue(); })

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 概要 64学时 3.5学分 章节安排 电子商务网站概况 HTML5+CSS3 JavaScript Node 电子...
    阿啊阿吖丁阅读 9,368评论 0 3
  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,406评论 0 2
  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,211评论 0 1
  • 隐藏元素的hide方法 让页面上的元素不可见,一般可以通过设置css的display为none属性。但是通过css...
    老夫撩发少年狂阅读 1,119评论 0 2
  • 瘦瘦的不太高的个子,英俊的脸庞,一双会说话的眼睛,豪情与斗志溢于言表……他是我大姑姑的小儿子,我的小表哥,我们从小...
    陌上花开2016阅读 404评论 0 0