jQuery中animate()方法七种用法与注意事项

2018-03-2510:21:08WEB前端开发Comments3,091 views字数 1835阅读模式
jQuery的中的animate()方法还停留在最常见的用法,查了一下手册,发现在1.8的时候增加了几个比较有用的回调函数,想着就来总结下jQuery中animate的几种用法与注意事项。

一、animate语法结构

animate(params,speed,callback)

params:一个包含样式属性及值的映射,比如{key1:value1,key2:value2}文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

speed:速度参数[可选]文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

callback:在动画完成时执行的函数[可选]文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

二、自定义简单动画

用一个简单例子来说明,实现单击某div在页面上横向飘动的效果。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<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。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

jQuery中animate()方法七种用法与注意事项
演示效果文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

三、累加、累减动画

在之前的代码中,设置了{left:"100px"}这个属性作为参数,如果改写为{left:"+=25px"} ,效果如下文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

jQuery中animate()方法七种用法与注意事项
演示效果文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

四、多重动画

同时执行多个动画文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

上面的例子是一个很简单的动画。如果想同时执行多个动画,比如在元素向右滑动的同时,放大元素高度。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

代码如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

1
$(this).animate({left:"+=25px",height:"+=20px"},1000)

jQuery中animate()方法七种用法与注意事项文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

演示效果文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

五、按顺序执行多个动画

上例中,向右滑动与高度变大是同时发生的,如果想让方块先向右滑动再变高,只需将代码拆分文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

1
2
$(this).animate({left:"+=25px"},500)
  .animate({height:"+=20px"},500)

像这样的动画效果的执行有先后顺序,称为“动画队列”文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

jQuery中animate()方法七种用法与注意事项
演示效果文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

六、综合示例

单击方块,让他向右移动的同时增高,不透明度从50%增加到100%,之后上下移动,加宽,完成后淡出。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

1
2
3
4
5
$("#cube").click(function(){
    $(this).animate({left:"100px",height:"100px",opacity:"1"},500)
    .animate({top:"40px",width:"100px"},500)
    .fadeOut('slow')
   })

为同一元素应用多重效果时可以通过链式方式对这些效果进行排队。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

jQuery中animate()方法七种用法与注意事项
演示效果
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

七、动画回调函数

在上例中,如果想在最后一步切换css样式(background:blue),而不是淡出,如果按照通常处理,相关代码如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

1
2
3
4
5
$("#cube").click(function(){
    $(this).animate({left:"100px",height:"100px",opacity:"1"},500)
    .animate({top:"40px",width:"100px"},500)
    .css("border","5px solid blue")//改动这行
   })

然而,css()方法被提前调用。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

jQuery中animate()方法七种用法与注意事项
演示效果文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

引起这个问题的原因是,css()方法不会加入到动画队列中,而是立即执行。可以使用回调函数对非动画方法实现排队。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

正确的相关代码如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

1
2
3
4
5
6
$("#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")
 })
})

jQuery中animate()方法七种用法与注意事项文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

演示效果文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

值得注意的是,callback适用于jquery所有的动画方法,比如slidDown() ,show()等。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html

文章源自菜鸟学院-https://www.cainiaoxueyuan.com/gcs/2512.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/gcs/2512.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定