基础效果

.hide([duration ] [,easing ] [,complete ])

用于隐藏元素,没有参数的时候等同于直接设置 display 属性

$('.target').hide()
//等同于
$('.target').css('display', 'none')

.show()

用于显示元素,用法和hide类似

$('#btn-box1').on('click',function(){
$('.box').show('normal')
})

.toggle()

用来切换元素的隐藏、显示,类似于toggleClass,用法和showhide类似

渐变效果

.fadeIn()

以淡入的方式显示匹配元素

$('#btn-box3').on('click',function(){
$('.box').fadeIn()
})

.fadeOut()

以淡出的方式显示匹配元素

$('#btn-box4').on('click',function(){
$('.box').fadeOut()
})

.fadeTo()

调整匹配元素的透明度,方法通过匹配元素的不透明度做动画效果

$('#book').fadeTo('slow', 0.5, function() {
// Animation complete.
});

滑动效果

.slideDown() / .slideUp()

用滑动动画显示一个匹配元素

$('#btn-box5').on('click',function(){
$('.box').slideDown()
}) $('#btn-box6').on('click',function(){
$('.box').slideUp()
})

回调同步 与 异步

如以下案例

回调同步

即在整个动画结束之后,出现'hide',即为同步

$('#btn-box1').on('click',function(){
$('.box').hide('normal', funciton(){
console.log('hide')
})
})

异步

即只要事件触发瞬间(即按下btn),就出现'hide',即为异步

$('#btn-box1').on('click',function(){
$('.box').hide('normal')
console.log('hide')
})

具体参考 demo 案例 1 中的案例

$('#action1').on('click',function(){
var $box = $('.box') //回调地狱写法
$box.hide(1000, function(){
$box.show(1000, function(){
$box.fadeOut('slow', function(){
$box.fadeIn('slow', function(){
$box.slideUp(function(){
$box.slideDown(function(){
console.log('动画执行完毕')
$('#wrap1').text('动画执行完毕')
})
})
})
})
})
})
}) $('#action2').on('click',function(){
var $box = $('.box') //使用jQuery动画队列写法
$box.hide(1000)
.show(1000)
.fadeOut('slow')
.fadeIn('slow')
.slideUp()
.slideDown(function(){
console.log('真的执行完毕了')
$('#wrap2').text('真的执行完毕了') //最后执行同步回调
})
console.log('动画完毕了吗?') //动画才刚开始,在动画队列创建的时候,就输出这句话,异步
$('#wrap2').text('动画完毕了吗?')
})
 

jQuery 动画队列

动画队列可以说是动画执行的一个顺序机制,当我们对一个对象添加多次动画效果时后,添加的动作就会被放入这个动画队列中,等前面的动画完成后再开始执行。

 

动画队列机制和执行顺序

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

即参考之前的 回调同步、异步。

以上是整个动画的调度一个流程,其实都是利用队列异步的空闲然后执行同步的代码,这样在处理上是没有浪费资源的,而且精确度也是最高的。

自定义动画

当基础效果、渐变效果、滑动效果动画不能满足需求的时候,jQuery 提供了自定义动画行为的方法

.animate( properties [, duration ] [, easing ] [, complete ] )

properties是一个 CSS属性和值 的对象,动画将根据这组对象移动。

$('#btn4').click(function(){
$('.box').animate({
left: '150px'
},1000)
.animate({
left: '150px',
top: '150px'
},1000)
.animate({
left: '0',
top: '150px'
},1000)
.animate({
left: '0',
top: '0'
},1000)
})

.clearQueue()

清除 动画队列 中未执行的动画

.stop( [clearQueue ] [, jumpToEnd ] )

停止当前正在运行的动画
里面的参数

  • clearQueue:即是.clearQueue()方法,决定是否清楚 动画队列 中未执行的动画
  • jumpToEnd:即是决定是否展示当前一帧动画是否执行到最后

这两个参数默认都为false
.stop()等同于.stop(false,false)

.stop(false,false)

动画序列中共有 4 个序列,当执行到 动画序列2 的时候 使用.stop(),序列2 立即停止,并执行 动画序列3 ,执行完之后,执行动画序列4。

 

进入 demo 点击 auto 之后,再点击 .stop() 即可查看效果

.stop(true,false)

动画序列中共有 4 个序列,当执行到 动画序列2 的时候 使用.stop(true,false),序列2 立即停止,由于参数 [clearQueue]是 true 因此后面的也动画序列也全部清空,不会再往下执行动画序列。因此动画会停留在 动画序列2 .stop(true,false)的地方。

 

进入 demo 点击 auto 之后,再点击 .stop(true,false) 即可查看效果

.stop(true,true)

动画序列中共有 4 个序列,当执行到 动画序列2 的时候 使用.stop(true,true),由于参数 [clearQueue]是 true 因此后面的也动画序列也全部清空,不会再往下执行动画序列。由于参数 [jumpToEnd]也是 true ,因此 最后会停留在 动画序列2 本身应该结束的位置。

 

进入 demo 点击 auto 之后,再点击 .stop(true,true) 即可查看效果

.finish()

停止当前动画,并清除 动画队列 中所有未完成的动画,最终展示 动画队列 最后一帧的最终状态

 

进入 demo 点击 auto 之后,再点击 .finish() 即可查看效果

相关案例

之前提到的 基础效果、渐变效果、滑动效果、回调同步与异步、动画队列都包含在以下 demo 案例中
demo 案例 1

自定义动画 / 动画队列说明 包含在以下 demo 案例中
demo 案例 2

参考

jQuery API
jQuery 动画队列
深入学习 jQuery 动画队列

jQuery 动画效果 与 动画队列的更多相关文章

  1. html5--6-55 动画效果-关键帧动画

    html5--6-55 动画效果-关键帧动画 实例 @charset="UTF-8"; div{ width: 150px; height: 150px; font-size: 2 ...

  2. Object-C 里面的animation动画效果,核心动画

    #import "CoreAnimationViewController.h" @interface CoreAnimationViewController ()@property ...

  3. jQuery的效果(动画)

    jquery的效果(动画) show 概念:显示隐藏的匹配元素 语法:show(speed,callback) 参数:speed:三种预定速度之一的字符串('slow','normal','fast' ...

  4. jQuery插件实例五:手风琴效果[动画效果可配置版]

    昨天写了个jQuery插件实例四:手风琴效果[无动画版]那个是没有动画效果的,且可配置性不高,本篇为有动画效果.对于一些数据做了动态的计算,以实现自适应. 欢迎大家入群相互交流,学习,新群初建,欢迎各 ...

  5. Vue过渡和动画效果展示(案例、GIF动图演示、附源码)

    前言 本篇随笔主要写了Vue过渡和动画基础.多个元素过渡和多个组件过渡,以及列表过渡的动画效果展示.详细案例分析.GIF动图演示.附源码地址获取. 作为自己对Vue过渡和动画效果知识的总结与笔记. 因 ...

  6. Android动画效果之Tween Animation(补间动画)

    前言: 最近公司项目下个版本迭代里面设计了很多动画效果,在以往的项目中开发中也会经常用到动画,所以在公司下个版本迭代开始之前,抽空总结一下Android动画.今天主要总结Tween Animation ...

  7. Android中的动画效果

    动画的种类 透明动画alphaAnimation 在代码中配置动画: findViewById(R.id.btnAnimMe).setOnClickListener(new View.OnClickL ...

  8. css3实现的3中loading动画效果

    一.css3中animation动画各种属性详解: animation Value:     [<animation-name> || <animation-duration> ...

  9. Android动画效果translate、scale、alpha、rotate详解

    动画类型 Android的animation由四种类型组成 XML中 alpha 渐变透明度动画效果 scale 渐变尺寸伸缩动画效果 translate 画面转换位置移动动画效果 rotate 画面 ...

随机推荐

  1. OpenfileDialog选择照片的简单应用

    OpenFileDialog openFileDlg = new OpenFileDialog(); openFileDlg.Title = "选择文件"; openFileDlg ...

  2. 关于IE8下media query兼容的解决方案探讨

    在国内IE8至少还占有20%的市场份额,所以在做网站时,必须得为这部分用户特殊兼容考虑. 一方面IE8上面很多css3定义的标签不能使用,另外一方面javascript的addEventListene ...

  3. 未在本机注册Microsoft.ACE.OleDb.12.0

    服务器版本:Windows Server 2008 R2 64位.IIS7 已经安装了Microsoft Access database engine 2010 X64. 在服务器上可以用SQL Se ...

  4. Access 64-bit HKLM\Software Registry by 32-bit C#.NET Application

    http://www.codeproject.com/Articles/1003177/Access-bit-HKLM-Software-Registry-by-bit-Csharp-NE While ...

  5. Beyond Compare 4的试用期过了怎么办

    修改配置文件(C:\Users\gaojs\AppData\Roaming\BCompare\BCompare.ini)中的时间戳. 时间戳在线转换:https://tool.lu/timestamp ...

  6. leveldb分析——Arena内存管理

    leveldb中实现了一个简单的内存管理工具Arena,其基本思想为:先预先向系统申请一块内存,此后需要申请内存时,直接到预先分配的内存中申请. 那么这样做的目的是什么呢? (1)避免了频率地进行ma ...

  7. python 函数&条件,循环

    条件if <条件判断1>: <执行1>elif <条件判断2>: <执行2>elif <条件判断3>: <执行3>else: & ...

  8. Java日志系统

    前言 各组件之间的关系: slf4j是The Simple Logging Facade for Java的简称,是一个简单日志门面抽象框架,它本身只提供了日志Facade API和一个简单的日志类实 ...

  9. zt 李鸿章听过《彩云追月》?

    ZT 李鸿章听过<彩云追月>? 2013-05-11 09:35:52 编辑 删除 归档在 观世上之音 | 浏览 1041 次 | 评论 1 条 尝试在网上找一点有关<彩云追月> ...

  10. 使用log4j让日志写入数据库

    之前做的一个项目有这么个要求,在日志管理系统里,需要将某些日志信息存储到数据库里,供用户.管理员查看分析.因此我就花了点时间搞了一下这一功能,各位请看. 摘要:我们知道log4j能提供强大的可配置的记 ...