jQuery中animate的几种用法与注意事项
一、animate语法结构
animate(params,speed,callback)
params:一个包含样式属性及值的映射,比如{key1:value1,key2:value2}
speed:速度参数[可选]
callback:在动画完成时执行的函数[可选]
二、自定义简单动画
用一个简单例子来说明,实现单击某div在页面上横向飘动的效果。
<style> #cube{ position:relative;/* 不加这句元素不能动 */ width:30px; height:30px; background:red; cursor:pointer; } </style> <body> <div> <div id="cube"></div> </div> <script> $(function(){ $("#cube").click(function(){ $(this).animate({left:"100px"},2000) }) }) </script>
为了使元素动起来,要改变left属性。为了能影响元素top、right、bottom、left属性值必须声明元素的position。
演示效果
三、累加、累减动画
在之前的代码中,设置了{left:"100px"}
这个属性作为参数,如果改写为{left:"+=25px"}
,效果如下
演示效果
四、多重动画
同时执行多个动画
上面的例子是一个很简单的动画。如果想同时执行多个动画,比如在元素向右滑动的同时,放大元素高度。
代码如下:
$(this).animate({left:"+=25px",height:"+=20px"},1000)
演示效果
五、按顺序执行多个动画
上例中,向右滑动与高度变大是同时发生的,如果想让方块先向右滑动再变高,只需将代码拆分
如下:
$(this).animate({left:"+=25px"},500) .animate({height:"+=20px"},500)
像这样的动画效果的执行有先后顺序,称为“动画队列”
演示效果
六、综合示例
单击方块,让他向右移动的同时增高,不透明度从50%增加到100%,之后上下移动,加宽,完成后淡出。
$("#cube").click(function(){ $(this).animate({left:"100px",height:"100px",opacity:"1"},500) .animate({top:"40px",width:"100px"},500) .fadeOut('slow') })
为同一元素应用多重效果时可以通过链式方式对这些效果进行排队。
演示效果
七、动画回调函数
在上例中,如果想在最后一步切换css样式(background:blue),而不是淡出,如果按照通常处理,相关代码如下:
$("#cube").click(function(){ $(this).animate({left:"100px",height:"100px",opacity:"1"},500) .animate({top:"40px",width:"100px"},500) .css("border","5px solid blue")//改动这行 })
然而,css()
方法被提前调用。
演示效果
引起这个问题的原因是,css()
方法不会加入到动画队列中,而是立即执行。可以使用回调函数对非动画方法实现排队。
正确的相关代码如下:
$("#cube").click(function(){ $(this).animate({left:"100px",height:"100px",opacity:"1"},500) .animate({top:"40px",width:"100px"},500,function(){ $(this).css("border","5px solid blue") }) })
演示效果
值得注意的是,callback适用于jquery所有的动画方法,比如slidDown()
,show()
等。
总结
以上就是关于jquery中animate的几种用法和注意事项,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。谢谢大家对脚本之家的支持。
- JQuery animate动画应用示例
- jQuery封装animate.css的实例
- jquery animate动画持续运动的实例
- jQuery中animate()的使用方法及解决$(”body“).animate({“scrollTop”:top})不被Firefox支持的问题
- jQuery animate()实现背景色渐变效果的处理方法【使用jQuery.color.js插件】
- 浅谈原生JS实现jQuery的animate()动画示例
- jQuery实现立体式数字动态增加(animate方法)
- jQuery使用animate实现ul列表项相互飘动效果示例
- 利用jQuery的动画函数animate实现豌豆发射效果
- 原生js实现jquery函数animate()动画效果的简单实例
- 详解jQuery的animate动画方法及动画排队问题解决
相关文章
Jquery validation remote 验证的缓存问题解决方法
这篇文章主要介绍了Jquery validation remote 验证的缓存问题的解决方法 ,需要的朋友可以参考下2014-03-03jQuery插件学习教程之SlidesJs轮播+Validation验证
这篇文章主要介绍了jQuery插件学习教程之SlidesJs轮播+Validation验证的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下2016-07-07jquery使用remove()方法删除指定class子元素
这篇文章主要介绍了jquery使用remove()方法删除指定class子元素的方法,可实现删除指定元素下指定class的子元素功能,具有一定参考借鉴价值,需要的朋友可以参考下2015-03-03
最新评论