锋利的jQuery-4--animate()的用法

1.一般动画:

$("btn").click(function(){
    $("div").animate({"left" : "+=300px"}, 300);  //需要div设置了元素的position属性,否则不管用
});

2.多重动画:

元素在向右滑动的同时,放大元素的高度。

$("btn").click(function(){
    $("div").animate({"left" : "300px", "height" : "200px"}, 300);  //需要div设置了元素的position属性,否则不管用
});

元素向右滑动之后,再放大元素的高度。(像这样动画执行效果具有先后顺序,称之为动画队列)

$("btn").click(function(){
    $("div").animate({"left" : "300px"}, 300)
   .animate({"height" : "200px"}, 300); //需要div设置了元素的position属性,否则不管用 });

3.综合动画:

元素先向右移动同时增大高度并且透明度从50%到100%,然后向下移动同时增大宽度,最后淡出隐藏。

$("btn").click(function(){
    $("div").css("opacity", "0.5");
    $("div").animate({"left" : "300px", "height":"200px", "opacity" : "1" }, 300)
   .animate({"top" : "200px", "width" : "200px"}, 300)
   .fadeOut("slow"); //需要div设置了元素的position属性,否则不管用 });

注意:如果动画执行完后不是fadeOut(),而是要改css样式,例如:.css({"border" : "5px solid blue"}),并不能得到预期的效果,因为css在动画开始执行的时候,css方法就被执行了。需要使用回调函数:

$("btn").click(function(){
    $("div").css("opacity", "0.5");
    $("div").animate({"left" : "300px", "height":"200px", "opacity" : "1" }, 300)
   .animate({"top" : "200px", "width" : "200px"}, 300, function(){
      $(this).css("border" : "5px solid blue");
   });  //需要div设置了元素的position属性,否则不管用
});

callback回调函数适用于所有jQuery动画效果方法(show,slideDown等)

 

posted @ 2014-10-29 19:55  leezhxing  阅读(206)  评论(0编辑  收藏  举报