源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

jQuery中animate的几种用法与注意事项

  • 时间:2020-03-01 22:37 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:jQuery中animate的几种用法与注意事项
[b]一、animate语法结构[/b]
animate(params,speed,callback)
params:一个包含样式属性及值的映射,比如[code]{key1:value1,key2:value2}[/code] speed:速度参数[可选] callback:在动画完成时执行的函数[可选] [b]二、自定义简单动画[/b] 用一个简单例子来说明,实现单击某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。 [img]http://files.jb51.net/file_images/article/201612/20161212114533725.gif?20161112114542[/img] 演示效果 [b]三、累加、累减动画[/b] 在之前的代码中,设置了[code]{left:"100px"}[/code]这个属性作为参数,如果改写为[code]{left:"+=25px"} [/code],效果如下 [img]http://files.jb51.net/file_images/article/201612/20161212114624366.gif?20161112114631[/img] 演示效果 [b]四、多重动画[/b] 同时执行多个动画 上面的例子是一个很简单的动画。如果想同时执行多个动画,比如在元素向右滑动的同时,放大元素高度。 [b]代码如下:[/b]
$(this).animate({left:"+=25px",height:"+=20px"},1000)
[img]http://files.jb51.net/file_images/article/201612/20161212114709778.gif?20161112114715[/img] 演示效果 [b]五、按顺序执行多个动画[/b] 上例中,向右滑动与高度变大是同时发生的,如果想让方块先向右滑动再变高,只需将代码拆分 [b]如下:[/b]
$(this).animate({left:"+=25px"},500)
  .animate({height:"+=20px"},500)
像这样的动画效果的执行有先后顺序,称为“动画队列” [img]http://files.jb51.net/file_images/article/201612/20161212114824411.gif?20161112114832[/img] 演示效果 [b]六、综合示例[/b] 单击方块,让他向右移动的同时增高,不透明度从50%增加到100%,之后上下移动,加宽,完成后淡出。
$("#cube").click(function(){
    $(this).animate({left:"100px",height:"100px",opacity:"1"},500)
    .animate({top:"40px",width:"100px"},500)
    .fadeOut('slow')
   })
为同一元素应用多重效果时可以通过链式方式对这些效果进行排队。 [img]http://files.jb51.net/file_images/article/201612/20161212114921843.gif?20161112114928[/img] [b]演示效果 [/b] [b]七、动画回调函数[/b] 在上例中,如果想在最后一步切换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")//改动这行
   })
然而,[code]css()[/code]方法被提前调用。 [img]http://files.jb51.net/file_images/article/201612/20161212115024001.gif?20161112115031[/img] 演示效果 引起这个问题的原因是,[code]css()[/code]方法不会加入到动画队列中,而是立即执行。可以使用回调函数对非动画方法实现排队。 [b]正确的相关代码如下:[/b]
   $("#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")
    })
   })
[img]http://files.jb51.net/file_images/article/201612/20161212115120799.gif?20161112115128[/img] 演示效果 值得注意的是,callback适用于jquery所有的动画方法,比如[code]slidDown() [/code],[code]show()[/code]等。 [b]总结[/b] 以上就是关于jquery中animate的几种用法和注意事项,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。谢谢大家对编程素材网的支持。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部