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()等。

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,645评论 25 709
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,686评论 1 92
  • 一个女人 每个月流一次血象征着生命的来源
    摄影师柳丁阅读 1,020评论 0 2
  • 有人说女人过了30岁,世界仿佛就在一夜之间从五彩斑斓变成了单调色。不喜欢孤单,却又害怕吵闹。不满意当前,却又害怕太...
    魔导阅读 3,853评论 2 2
  • 时隔六年,再来京城,较之上次放松了不少,不再提前费劲巴拉地请在京的朋友协助做攻略,一切随遇而安。 上次来京住在护国...
    墨语花开时阅读 1,209评论 1 0