最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 20:27:41
文档

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

jQuery中animate的几种用法与注意事项:一、animate语法结构animate(params,speed,callback)params:一个包含样式属性及值的映射,比如{key1:value1,key2:value2}speed:速度参数[可选]callback:在动画完成时执行的函数[可选]二、自定义简单动画用一个简单例子来说明,实现单击某div在页面上横向
推荐度:
导读jQuery中animate的几种用法与注意事项:一、animate语法结构animate(params,speed,callback)params:一个包含样式属性及值的映射,比如{key1:value1,key2:value2}speed:速度参数[可选]callback:在动画完成时执行的函数[可选]二、自定义简单动画用一个简单例子来说明,实现单击某div在页面上横向
 一、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的几种用法与注意事项:一、animate语法结构animate(params,speed,callback)params:一个包含样式属性及值的映射,比如{key1:value1,key2:value2}speed:速度参数[可选]callback:在动画完成时执行的函数[可选]二、自定义简单动画用一个简单例子来说明,实现单击某div在页面上横向
推荐度:
标签: 使用 用法 注意
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top